一、BitMap
1、什么是BitMap
对于什么是BitMap,简单来说就是一种数据结构,一种基于位的数据结构。在Java中最小的基本数据类型是byte,学计算机的都应该知道一个byte=8bit也就是8个二进制位。
2、有什么用
对于有什么用这个问题就不好回答了,它就是一种数据结构,就行我们的List、Map啥的,有合适的场合就可以用,例如在后面我会讲到的布隆过滤器,就是一个最典型的使用场景。
3、基本结构
如图是一个以byte数组构建的BitMap数据结构,在内存中我们可以将整个数据看成是一片连续的bit位,即使不是一偏我们在提供API的时候也是操作成了连续的,再说数组在内存中的确是连续的,一般像这个数据结构多是用来快速判断数据是否存在:假如在一个集合中我们想要判断某数据是否存在,传统的方式是遍历整个集合,这样无疑性能是最差的,因此我们可以在往集合添加数据的时候顺带初始化下BitMap集合,假如我们往集合添加了4,这时只需要在第四个bit位上置1就代表4存在,这样便可以高效的判断数据是否存在。
4、Java实现
代码以int数组实现,其他类似,明白到理即可:
package club.mossflower.study.base.workbook;
import java.util.Random;
/**
* @ProjectName: mossflower
* @Package: club.mossflower.study.base.workbook
* @ClassName: BitMap
* @Author: liugenkun
* @Description: bitmap 实现
* @Date: 2019/12/15 15:21
* @Version: 1.0
*/
public class BitMap {
int[] ints;
int max;
public BitMap(int max){
this.max = max;
ints = new int[(max>>5)+1];
}
public void add(int n){
//找出在数组中的位置
int idxs = n>>5;
//找出int中的bit位(32为符号位)
int idx = n&(31);
//将对应bit位置1
ints[idxs] |= 1<< idx;
}
public void del(int n){
int idxs = n>>5;
int idx = n&(31);
//对应bit位置0
ints[idxs] &= ~(1<< idx);
}
public boolean find(int n){
int idxs = n>>5;
int idx = n&(31);
int flag = ints[idxs] &(1<< idx);
if (flag == 0){
return false;
}
return true;
}
public static void main(String[] args) {
BitMap bitMap = new BitMap(100);
bitMap.add(3);
Random random = new Random();
for (int i = 0;i<10;i++){
int i1 = random.nextInt(100);
System.out.print(i1);
System.out.print(" ");
bitMap.add(i1);
}
System.out.println();
for (int i=0;i<100;i++){
if (bitMap.find(i)){
System.out.println(i);
}
}
for (int i=0;i<100;i++){
if (bitMap.find(i)){
bitMap.del(i);
}
}
for (int i=0;i<100;i++){
if (bitMap.find(i)){
System.out.println(i);
}
}
}
}
其实整个挺简单的,所以就没做其他讲解,希望对看到的朋友有所帮助,下一篇,主要谈谈布隆过滤器。