java进阶——从BitMap到布隆过滤器(一)

一、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);
            }
        }

    }
}

其实整个挺简单的,所以就没做其他讲解,希望对看到的朋友有所帮助,下一篇,主要谈谈布隆过滤器。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值