热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

JavaBitmap位图使用

文章目录1.数据结构的定义2.查询方法的实现3.修改方法的实现        在Java中使用byte[]字节数组来储存bit,1byte=8bit。对于bit中的第i位,该bit

文章目录





    • 1. 数据结构的定义

    • 2. 查询方法的实现

    • 3. 修改方法的实现



        

在Java中使用byte[]字节数组来储存bit,1byte = 8bit。对于bit中的第i位,该bit为1则表示true,即数据存在:为0则表示false,即数据不存在。其具体实现分为数据结构的定义、查询方法和修改方法的实现

1. 数据结构的定义

        在如下代码中定义了一个名为Bitmap的类用于位图数据结构的存储,其中byte[]数组用于存储具体的数据,length用于记录数据的长度:

//以bit为存储单位的数据结构,对于给定的第i位,1表示true,0表示false
public class Bitmap{
private byte[] bytes;
//length为位图的长度,实际可操作的下标为[0,length)
private int length;
public Bitmap(int length){
this.length = length;
bytes = new byte[length%8==0 ? length/8 : length/8+1];
}
}

2. 查询方法的实现

        位图的查询操作为在拿到目标bit所在的Byte后,将其向右位移(并将高位置0),是目标bit在第一位,这样结果值就是目标bit值,方法如下:



  1. 通过byte[index>>3](等价于byte[index/8])取到目标bit所在的Byte

  2. 令 i = index&7(等价于index%8),使得目标bit在该Byte中的位置

  3. 为了将目标bit前面的高位置0(这样位移后的值才等于目标bit本身),需要构建到目标bit为止的低位掩码,即01111111>>>(7-i),再与原Byte做&运算

  4. 将结果向右位移i位,使目标bit位处于第1位,结果值即为所求

//获取指定位的值
public boolean get(int index){
int i = index & 7;
//构建到index结束的低位掩码并做&运算(为了将高位置0),然后将结果一直右移,
//直到目标位(index位)移到第一位,然后根据其值返回结果
if((bytes[index >> 3] & (01111111 >>> (7-i))) >> i == 0)
return false;
else
return true;
}

3. 修改方法的实现

        对位图的修改操作根据设定值true或false的不同,分为两种情况



  1. 如果value为true,则表示数据存在,将目标位与1做或运算,需要构建目标位为1、其他位为0的操作数

  2. 如果value为false&#xff0c;则表示数据不存在&#xff0c;将目标位与0做与运算&#xff0c;需要构建目标位为0、其他位为1的操作数。构建目标位为1且其他位为0的操作数的做法为&#xff1a;1 <<(index & 7)

//设置指定位的值
public void set(int index, boolean value){
if(value)
//通过给定位index&#xff0c;先定位到对应的Byte&#xff0c;并根据value值进行不同位的操作&#xff1a;
//1.如果value为true&#xff0c;则目标位应该做或运算&#xff0c;构建“目标位为1&#xff0c;
//其他位为0”的操作数&#xff0c;为了只合理操作目标位&#xff0c;而不影响其他位
//2.如果value为false&#xff0c;则目标位应该做与运算&#xff0c;构建“目标位为0&#xff0c;
//其他位为1”的操作数
bytes[index >> 3 ] |&#061; 1 << (index & 7 );
//byte[index/8] &#061; byte[index/8] | (0b0001 <<(index%8))
else
bytes[index >> 3 ] &&#061; ~(1 << (index & 7 ));
}

本文地址:https://blog.csdn.net/weixin_44556968/article/details/110287626



推荐阅读
  • 先看官方文档TheJavaTutorialshavebeenwrittenforJDK8.Examplesandpracticesdescribedinthispagedontta ... [详细]
  • BitMap的原理和实现方法
    这篇文章主要介绍“BitMap的原理和实现方法”,在日常操作中,相信很多人在BitMap的原理和实现方法问题上存在疑惑,小编查阅了各式资料,整理出简 ... [详细]
  • Java中包装类的设计原因以及操作方法
    本文主要介绍了Java中设计包装类的原因以及操作方法。在Java中,除了对象类型,还有八大基本类型,为了将基本类型转换成对象,Java引入了包装类。文章通过介绍包装类的定义和实现,解答了为什么需要包装类的问题,并提供了简单易用的操作方法。通过本文的学习,读者可以更好地理解和应用Java中的包装类。 ... [详细]
  • 本文介绍了Swing组件的用法,重点讲解了图标接口的定义和创建方法。图标接口用来将图标与各种组件相关联,可以是简单的绘画或使用磁盘上的GIF格式图像。文章详细介绍了图标接口的属性和绘制方法,并给出了一个菱形图标的实现示例。该示例可以配置图标的尺寸、颜色和填充状态。 ... [详细]
  • 纠正网上的错误:自定义一个类叫java.lang.System/String的方法
    本文纠正了网上关于自定义一个类叫java.lang.System/String的错误答案,并详细解释了为什么这种方法是错误的。作者指出,虽然双亲委托机制确实可以阻止自定义的System类被加载,但通过自定义一个特殊的类加载器,可以绕过双亲委托机制,达到自定义System类的目的。作者呼吁读者对网上的内容持怀疑态度,并带着问题来阅读文章。 ... [详细]
  • 本文讨论了在VMWARE5.1的虚拟服务器Windows Server 2008R2上安装oracle 10g客户端时出现的问题,并提供了解决方法。错误日志显示了异常访问违例,通过分析日志中的问题帧,找到了解决问题的线索。文章详细介绍了解决方法,帮助读者顺利安装oracle 10g客户端。 ... [详细]
  • 要点:假如有10亿元素,全部数据读进内存,占用1000000000*4102410241024≈3.725G,爆炸!解决方法:bitmap算法,每一位都能 ... [详细]
  • 从具有确切位置的两个imageView创建位图 - Create bitmap from two imageView with exact location
    MyTarget:Getonephotofromcameraorgallery,thensetittoimageViewA从相机或图库中获取一张照片,然后将其设置 ... [详细]
  • Android 性能优化系列之bitmap图片优化
    在日常开发的APP,大部分时候需要想用户展示图片信息,图片最终对应Android中的Bitmap对象。而对于APP端来说Bitmap又是一个比较麻烦的问题,主要表现在Bitmap是非常占用内存的对象,处理不当将导致APP运行卡顿甚至出现OOM ... [详细]
  • 本文介绍了使用哈夫曼树实现文件压缩和解压的方法。首先对数据结构课程设计中的代码进行了分析,包括使用时间调用、常量定义和统计文件中各个字符时相关的结构体。然后讨论了哈夫曼树的实现原理和算法。最后介绍了文件压缩和解压的具体步骤,包括字符统计、构建哈夫曼树、生成编码表、编码和解码过程。通过实例演示了文件压缩和解压的效果。本文的内容对于理解哈夫曼树的实现原理和应用具有一定的参考价值。 ... [详细]
  • 本文分析了Wince程序内存和存储内存的分布及作用。Wince内存包括系统内存、对象存储和程序内存,其中系统内存占用了一部分SDRAM,而剩下的30M为程序内存和存储内存。对象存储是嵌入式wince操作系统中的一个新概念,常用于消费电子设备中。此外,文章还介绍了主电源和后备电池在操作系统中的作用。 ... [详细]
  • 本文介绍了在C#中SByte类型的GetHashCode方法,该方法用于获取当前SByte实例的HashCode。给出了该方法的语法和返回值,并提供了一个示例程序演示了该方法的使用。 ... [详细]
  • Android中Bitmap与Drawable的区别有哪些?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更 ... [详细]
  • Iamtryingtodevelopanapponcanvas,Iamdrawingabitmaponthecanvas.Afterdrawing,iamtryin ... [详细]
  • 请高手解答:GDI+BitMapnew成功,GetLastStatus返回无效。delete指针崩溃,求解答代码如下:Bitmap*pBitmap::newBitma ... [详细]
author-avatar
手机用户2502931303
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有