理解布隆过滤器、使用场景

1.布隆过滤器基础

简单来说,布隆过滤器可以看作是一个【位数组】。存的都是0或者1。
位数组中每个元素都只占用1bit;
它是一种概率性数据结构,可以实现高效插入和查询。
通常都是用来检索某个元素是否在给定的大集合中***
能告诉你:XXX一定不存在或者可能存在,给你的结果不是确切的,更加的
高效、占用空间小
*。
在这里插入图片描述

2.布隆过滤器原理?(如何使用它去判断元素是否存在)

思考:通常情况下,我们判断某个元素是否存在,会使用HashMap,因为Key是唯一的,我们就可以去查询一个元素的Key,而去找到这个元素。时间复杂度是O(1),效率很高。但是当存储的数据量很大时,也会占用很大内存。
布隆过滤器可以实现更加快速的查询。
如图所示,当字符串存储要加入到布隆过滤器中时,该字符串首先由多个哈希函数生成不同的哈希值,然后在对应的位数组的下表的元素设置为 1(当位数组初始化时 ,所有位置均为0)。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值