Redis布隆过滤器原理和实现

1、为什么使用BitMaps?
一般情况下,计算机用二进制存储,一个字符=2个字节,中文一个字符=3个字节,一个字节是8位bit;
在有些特殊的业务场景下(比如用户是否活跃),实际有效的存储只有1位,0或1,如果使用字符串的存储,8位的话会造成空间浪费;

如何解决?
a、引入BitMaps,使用1位来表示这种value值只有1位的数据类型,节约空间
b、BitMaps可以理解为是:boolean[] arry,
c、比如某个用户在哪个时间范围内是否活跃,使用BitMaps存储:setbit  key(用户id+日期)   偏移量(在数组中的位置)  value(0或1),在进行用户活跃数统计时,bitcount   key得出用户活跃总数;


2、布隆过滤器,是一种程序或者方法,用来判断一个元素是否在一个集合中:
这种算法由一个二进制数组和一个Hash算法组成,是一种概率型的算法
这种算法有一个作用:判断某个元素是否在某个集合里面

那么问题来了:

集合的操作(交并补差不是用set集合也可以?)还是那个问题,set占用8个bit,而BitMaps只占用一位!

3、布隆过滤器的实现原理:

a、定义一个二进制数组:就是BitMaps(BitMaps就是一个二进制数组)
b、实现Hash算法:对setbit的va

  • 13
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值