布隆过滤器的原理_什么是布隆过滤器

布隆过滤器的原理_什么是布隆过滤器啊哈,布隆过滤器,你值得拥有

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

作用嘛就是用来过滤非法key,避免缓存穿透(请求直接打到数据库),布隆过滤器底层用的是位数组,不仅节省空间,性能也嘎嘎猛,而且占用内存不会随着使用变大

先贴demo后BB

public class MyBloomFilter { 
   
    //后面hash函数会用到,用来生成不同的hash值,可以随便给,但别给奇数
    private final int[] ints = { 
   6, 8, 16, 38, 58, 68};
    private Integer currentBeanCount = 0;
    //你的布隆过滤器容量
    private int DEFAULT_SIZE = Integer.MAX_VALUE;
    //bit数组,用来存放结果
    private final BitSet bitSet = new BitSet(DEFAULT_SIZE);

    public MyBloomFilter() { 
   
    }

    public MyBloomFilter(int size) { 
   
        if (size <= (2 << 8)) throw new RuntimeException("size is too small");
        DEFAULT_SIZE = size;
    }
	
	//获取当前过滤器的对象数量
    public Integer getCurrentBeanCount() { 
   
        return currentBeanCount;
    }

    //计算出key的hash值,并将对应下标置为true
    public void push(Object key) { 
   
        Arrays.stream(ints).forEach(i -> bitSet.set(hash(key, i)));
        currentBeanCount++;
    }

    //判断key是否存在,true不一定说明key存在,但是false一定说明不存在
    public boolean contain(Object key) { 
   
        boolean result = true;
        for (int i : ints) { 
   
            result = result && bitSet.get(hash(key, i));
        }
        return result;
    }

    //hash算法,借鉴了hashmap的算法
    private int hash(Object key, int i) { 
   
        int h;
        int index = key == null ? 0 : (DEFAULT_SIZE - 1 - i) & ((h = key.hashCode()) ^ (h >>> 16));
        return index > 0 ? index : -index;
    }
}

测试

    public static void main(String[] args) { 
   
        MyBloomFilter bf = new MyBloomFilter ();
        bf.add("张学友");
        bf.add("郭德纲");
        bf.add("蔡徐鸡");
        bf.add(666);
        System.out.println(bf.contain("张学友"));//true
        System.out.println(bf.contain("张学友 "));//false
        System.out.println(bf.contain("张学友1"));//false
        System.out.println(bf.contain("郭德纲"));//true
        System.out.println(bf.contain("蔡徐老母鸡"));//false
        System.out.println(bf.contain(666));//true
        System.out.println(bf.contain(888));//false
    }

原理

通过对比hash算法计算出来的下标,注意,我们是对比一组,而不是只看一次,一次hash结果对应一个下标

把同一个key进行多次hash运算,将hash出来的下标放入数组,数组默认全为0,放入元素后该下标就为1,后面判断是否存在元素的时候也是进行同样次数的hash运算,看下结果对应的所有下标是否全为1,若全为1,则代表该key可能存在,若存在不为1的,则说明该key一定不存在;

默认位数组:[0,0,0,0,0,0]
比方说有个已知key的下标是0,2,5
对应位数组:[1,0,1,0,0,1]
判断某个未知key存不存在的时候,假设我们计算出来的下标是0,2,4
对应位数组:[1,0,1,0,1,0]
此时位数组内5对应下标值为0,而已知key位数组的5对应下标位1,说明这两个一定不是同一个key

相反,如果某个key计算出来的下标为[1,0,1,0,0,1],只能说这个key可能存在,因为这个位置可能是其它key计算出来的

如果对上面的hash算法有疑惑,请移步帮你真正理解hashCode和hash算法


demo复制可用,家里有条件的都在编译器上跑一跑,测一测

ok我话讲完

嘤嘤嘤~

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/184925.html原文链接:https://javaforall.net

(0)
上一篇 2022年10月7日 下午3:16
下一篇 2022年10月7日 下午3:16


相关推荐

  • WebRTC 系列文章 ICE服务器搭建 coturn[通俗易懂]

    WebRTC 系列文章 ICE服务器搭建 coturn[通俗易懂]WebRTC系列文章ICE服务器搭建服务器环境安装coturn安装coturn依赖软件克隆代码仓库安装coturn修改配置克隆一份配置文件修改配置项启动coturn检测coturn工作状态coturn是一个C++编写的开源ICE服务器,同时兼顾了STUN和TURN的功能。服务器环境CentOS7云服务器一台安装coturn安装coturn依赖软件yumi…

    2022年6月13日
    103
  • C++中resize函数的用法

    resize(),设置大小;reserve(),设置容量;resize()是分配容器的内存大小,而reserve()只是设置容器容量大小,但并没有真正分配内存。resize()可以传递两个参数,分别是大小和初始值,初始值默认为0,reserve()只能传递一个参数,不能设置初始值,其初始值为系统随机生成。例:#include<iostream>#include&…

    2022年4月1日
    324
  • 使用 jQuery Validate 进行表单验证

    使用 jQuery Validate 进行表单验证jQueryValida 简介 jQueryValida 插件提供了强大的表单验证功能 能够让客户端表单验证变得更简单 同时它还提供了大量的可定制化选项 以满足应用程序的各种需求 该插件捆绑了一套非常有用的验证方法 包括 URL 和电子邮件验证 同时也提供了 API 允许用户自定义校验方法 提供的所有捆绑方法默认使用英语作为错误信息 且已翻译成其他 37 种语言 引入 jQueryValid

    2026年3月17日
    2
  • 汇编语言INC DEC JGE JG JLE JL JNE JE 都是什么意思

    汇编语言INC DEC JGE JG JLE JL JNE JE 都是什么意思INC 自增 1increaseDEC 自减 1decreaseJGE 前 gt 后 Jumpifgreate 前 gt 后 Jumpifgreate 前 lt 后 Jumpiflessor 前

    2026年3月17日
    2
  • Django(53)二次封装Response

    Django(53)二次封装Response前言有时候我们使用drf的Response,会发现默认返回的格式不太友好,每次我们都需要写入以下的格式returnResponse({"status":0,"

    2022年7月31日
    12
  • iic电平转换电路_光耦电平转换电路图

    iic电平转换电路_光耦电平转换电路图

    2022年8月10日
    12

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号