当前位置: 首页 > news >正文

上海网站建设上海网站制作上海浦东建设管理有限公司网站

上海网站建设上海网站制作,上海浦东建设管理有限公司网站,百度网站推广方案,wordpress建立的博客谷歌guava当Guava项目发布版本11.0时#xff0c;新添加的功能之一是BloomFilter类。 BloomFilter是唯一的数据结构#xff0c;用于指示元素是否包含在集合中。 使BloomFilter有趣的是#xff0c;它将指示元素是否绝对不包含或可能包含在集合中。 永远不会出现假阴性的特性使… 谷歌guava 当Guava项目发布版本11.0时新添加的功能之一是BloomFilter类。 BloomFilter是唯一的数据结构用于指示元素是否包含在集合中。 使BloomFilter有趣的是它将指示元素是否绝对不包含或可能包含在集合中。 永远不会出现假阴性的特性使BloomFilter成为用作警戒条件的绝佳候选者以帮助防止执行不必要和昂贵的操作。 虽然BloomFilters最近获得了很好的曝光但使用它意味着滚动自己的浏览器或通过Google搜索代码。 滚动自己的BloomFilter的麻烦在于获取正确的哈希函数来制作过滤器 有效。 考虑到Guava使用Murmur Hash来实现我们现在就拥有了一个有效的BloomFilter的有用性而该库只是一个库。 BloomFilter速成课程 BloomFilters本质上是位向量。 在较高级别BloomFilters以下列方式工作 将元素添加到过滤器。 将其哈希几次然后将索引与哈希结果匹配的位设置为1。 测试元素是否在集合中时请遵循相同的哈希过程并检查这些位是否设置为1或0。此过程是BloomFilter如何保证元素不存在的方法。 如果未设置这些位则根本不可能将该元素放入集合中。 但是肯定答案表示元素在集合中或发生哈希冲突。 可以在此处找到有关BloomFilter的更详细的描述并在此处找到有关BloomFilters的良好教程。 根据Wikipedia的说法Google在BigTable中使用BloomFilters来避免对不存在的项目进行磁盘查找。 另一个有趣的用法是使用BloomFilter优化SQL查询 。 使用番石榴BloomFilter 通过调用BloomFilter类上的static方法create来创建Guava BloomFilter 传递一个Funnel对象和一个int表示预期的插入次数。 漏斗也是Guava 11中的新功能它是一个可以将数据发送到Sink的对象。 以下示例是默认实现并且误报的百分比为3。 Guava提供了一个Funnels类其中包含两个静态方法这些方法提供Funnel接口的实现用于将CharSequence或字节数组插入到过滤器中。 //Creating the BloomFilter BloomFilter bloomFilter BloomFilter.create(Funnels.byteArrayFunnel(), 1000);//Putting elements into the filter //A BigInteger representing a key of some sort bloomFilter.put(bigInteger.toByteArray());//Testing for element in set boolean mayBeContained bloomFilter.mayContain(bitIntegerII.toByteArray()); 更新基于路易斯·沃瑟曼的评论以下是如何使用自定义Funnel实现为BigIntegers创建BloomFilter的方法 //Create the custom filter class BigIntegerFunnel implements FunnelBigInteger {Overridepublic void funnel(BigInteger from, Sink into) {into.putBytes(from.toByteArray());}}//Creating the BloomFilter BloomFilter bloomFilter BloomFilter.create(new BigIntegerFunnel(), 1000);//Putting elements into the filter //A BigInteger representing a key of some sort bloomFilter.put(bigInteger);//Testing for element in set boolean mayBeContained bloomFilter.mayContain(bitIntegerII);注意事项 正确估计预期插入的数量至关重要。 当插入过滤器的次数接近或超过预期的数目时BloomFilter开始填满结果将产生更多的误报直至无用之地。 还有另一个版本的BloomFilter.create方法该方法带有一个附加参数双精度表示所需的错误命中概率级别必须大于0且小于1。 错误命中概率的级别会影响用于存储或搜索元素的哈希数。 所需的百分比越低执行的哈希数越高。 结论 BloomFilter是开发人员可以在其工具箱中使用的有用项。 现在Guava项目使在需要时开始使用BloomFilter变得非常简单。 希望您喜欢这篇文章。 欢迎提出有用的意见和建议。 参考资料 Guava BloomFilter的单元测试演示 。 BloomFilter类 您想知道的所有关于BloomFilters的信息 。 BloomFilter教程 。 Wikipedia上的BloomFilter 。 参考来自我们的JCG合作伙伴 Bill Bejeck的Google Guava BloomFIlter来自“ 随机思考编码”博客。 翻译自: https://www.javacodegeeks.com/2012/12/google-guava-bloomfilter.html谷歌guava
http://www.zqtcl.cn/news/505671/

相关文章:

  • 接网站开发广州仿站定制模板建站
  • 资源网站源码下载制作软件的app有哪些
  • 免备案空间网站电子商务网站经营特色分析的主要内容包括
  • 遨游建站网站设计的基本知识
  • 延津县建设局网站景安网站上传完还要怎么做
  • 模板做网站达州住房和城乡建设部网站
  • 高端网站定做公司企业文化模板
  • iis7.5添加网站销售订单管理系统
  • 网站开发模板代码外贸流程知识
  • 免费网站有哪些邯郸去哪做网站改版
  • 商务网站开发的工作任务湖南专业网站建设
  • 怎样搭建免费网站什么网站做网页好
  • flash工作室网站模板天津seo培训班在哪里
  • 怎么做游戏推广网站扬中商城官网
  • html5 公众号 网站开发顺德手机网站建设
  • 上海医疗网站备案表千库网是什么
  • 陕西省西安市制作网站二次元 wordpress主题
  • 十堰网站建设weitian帮人做logo网站
  • 网站怎么做商家定位长沙网站建设长沙建设银行
  • 山西省建设厅网站查询哈尔滨网站开发电话
  • 网站建设app律师网站素材
  • 安徽 网站建设丹阳杨文军
  • 燃烧学课程网站建设怎么做网站的登录界面
  • 邹城网站定制wordpress托管套餐
  • 沧州网站优化公司logo网站免费
  • 网站制作公司知道万维科技建设银行企业网站无法打印回单
  • 个人网站做贷款广告知乎关键词搜索
  • 常熟外贸网站建设网站突然显示 建设中
  • 宜昌市住房和城乡建设官方网站泗洪网页设计
  • 计算机软件网站建设北京加盟网站建设