栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

用java实现一个非常简单的布隆过滤器

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

用java实现一个非常简单的布隆过滤器

在查redis缓存之前往往先经过布隆过滤器,达到防止缓存穿透的作用

布隆过滤器原理以及优缺点可以看博客

 布隆过滤器的原理,优缺点_m0_53611007的博客-CSDN博客_布隆过滤器的优缺点

看代码:

public class MyBloomFilter {
    private int[] bloomFilter = new int[1024];//存放标志的数组

    public void add(String key){//添加缓存key的函数
        int hash = key.hashCode() % bloomFilter.length > 0 ? key.hashCode() % bloomFilter.length : -key.hashCode() % bloomFilter.length;//计算hash
        if (bloomFilter[hash] == 1){//当前位置已经为1说明缓存过了
            return ;
        }else {
            bloomFilter[hash] = 1;
            return;
        }
    }
    public boolean findKey(String key){//查看key是否在过滤器中
        int hash = key.hashCode() % bloomFilter.length > 0 ? key.hashCode() % bloomFilter.length : -key.hashCode() % bloomFilter.length;
        if(bloomFilter[hash] == 1){
            return true;
        }
        return false;
    }

    public static void main(String[] args) {
        String s = "yuze";
        String s1 = "zhangsan";
        MyBloomFilter bloomFilter = new MyBloomFilter();
        bloomFilter.add(s);
        System.out.println(bloomFilter.findKey(s));
        System.out.println(bloomFilter.findKey(s1));
    }
}

结果:

 

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/736492.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号