浅谈布隆过滤器

布隆过滤器是什么?

1970年, 一个叫布隆的小伙子提出的布隆过滤器

布隆过滤器实际上是一个很长的二进制向量和一系列随机映射函数.

简单理解就是一个bit数组, 默认每个值都是0 , 在插入数据时, 将一个key值进行多次hash运算得到多个hash值, 然后把bit数组对应的多个索引位置改为1, 就标记了这个key是可以查到值的

在查询数据时, 就可以根据key进行与上面相同的运算得到的多个hash运算结果是否都是1, 判断查询的数据是否存在, 如果存在就放行, 如果不存在则进行处理 .

在这里插入图片描述


布隆过滤器是干什么的:

是可以防止缓存穿透问题: 有人恶意生成大量的key, 这些key数据库中是没有数据的, 所以缓存中自然也没有, 就直接穿透缓存去查库, 从而压垮数据库


布隆过滤器优缺点:

优点:

查询快, 占用存储空间也小;

缺点:

删除困难和存在误判(hash冲突导致),可能不存在的数据经过hash运算与之前存过的数据得到相同hash值, 被认为是存在, 然后就会放行 ,但是可以手动指定误差率.

( … 抛开其它不谈, 你就说快不快吧 ! )

总结:

一个元素一定不存在 或者 可能存在! 有一定的误判率但可通过代码调节误判率
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大木学长

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值