亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > Java > 正文

JAVA實現較完善的布隆過濾器的示例代碼

2024-07-14 08:42:37
字體:
來源:轉載
供稿:網友

布隆過濾器是可以用于判斷一個元素是不是在一個集合里,并且相比于其它的數據結構,布隆過濾器在空間和時間方面都有巨大的優勢。布隆過濾器存儲空間和插入/查詢時間都是常數。但是它也是擁有一定的缺點:布隆過濾器是有一定的誤識別率以及刪除困難的。本文中給出的布隆過濾器的實現,基本滿足了日常使用所需要的功能。

 

0 0 0 0 0 0 0 0 0 0

 

先簡單來說一下布隆過濾器。其實現方法就是:利用內存中一個長度為M的位數組B并初始化里面的所有位都為0,如下面的表格所示:

然后我們根據H個不同的散列函數,對傳進來的字符串進行散列,并且每次的散列結果都不能大于位數組的長度。布隆過濾器的誤判率取決于你使用多少個不同的散列函數,下面給出的代碼中,給出了一些參考的誤判率(參考代碼中的枚舉類:MisjudgmentRate)?,F在我們先假定有4個不同散列函數,傳入一個字符串并進行一次插入操作,這時會進行4次散列,假設到了4個不同的下標,這個時候我們就會去數組中,將這些下標的位置置為1,數組變更為:

 

0 1 0 1 1 0 0 0 0 1

 

如果接下來我們再傳入同一個字符串時,因為4次的散列結果都是跟上一次一樣的,所以會得出跟上面一樣的結果,所有應該置1的位都已經置1了,這個時候我們就可以認為這個字符串是已經存在的了。因此不難發現,這是會存在一定的誤判率的,具體由你采用的散列函數質量,以及散列函數的數量確定。

代碼如下:

import java.io.FileInputStream;import java.io.FileOutputStream;import java.io.ObjectInputStream;import java.io.ObjectOutputStream;import java.io.Serializable;import java.util.BitSet;import java.util.concurrent.atomic.AtomicInteger; public class BloomFileter implements Serializable { private static final long serialVersionUID = -5221305273707291280L; private final int[] seeds; private final int size; private final BitSet notebook; private final MisjudgmentRate rate; private final AtomicInteger useCount = new AtomicInteger(0); private final Double autoClearRate;  /** * 默認中等程序的誤判率:MisjudgmentRate.MIDDLE 以及不自動清空數據(性能會有少許提升) *  * @param dataCount *      預期處理的數據規模,如預期用于處理1百萬數據的查重,這里則填寫1000000 */ public BloomFileter(int dataCount) { this(MisjudgmentRate.MIDDLE, dataCount, null); }  /** *  * @param rate *      一個枚舉類型的誤判率 * @param dataCount *      預期處理的數據規模,如預期用于處理1百萬數據的查重,這里則填寫1000000 * @param autoClearRate *      自動清空過濾器內部信息的使用比率,傳null則表示不會自動清理, *      當過濾器使用率達到100%時,則無論傳入什么數據,都會認為在數據已經存在了 *      當希望過濾器使用率達到80%時自動清空重新使用,則傳入0.8 */ public BloomFileter(MisjudgmentRate rate, int dataCount, Double autoClearRate) { long bitSize = rate.seeds.length * dataCount; if (bitSize < 0 || bitSize > Integer.MAX_VALUE) {  throw new RuntimeException("位數太大溢出了,請降低誤判率或者降低數據大小"); } this.rate = rate; seeds = rate.seeds; size = (int) bitSize; notebook = new BitSet(size); this.autoClearRate = autoClearRate; }  public void add(String data) { checkNeedClear();  for (int i = 0; i < seeds.length; i++) {  int index = hash(data, seeds[i]);  setTrue(index); } }  public boolean check(String data) { for (int i = 0; i < seeds.length; i++) {  int index = hash(data, seeds[i]);  if (!notebook.get(index)) {  return false;  } } return true; }  /** * 如果不存在就進行記錄并返回false,如果存在了就返回true *  * @param data * @return */ public boolean addIfNotExist(String data) { checkNeedClear();  int[] indexs = new int[seeds.length]; // 先假定存在 boolean exist = true; int index;  for (int i = 0; i < seeds.length; i++) {  indexs[i] = index = hash(data, seeds[i]);   if (exist) {  if (!notebook.get(index)) {   // 只要有一個不存在,就可以認為整個字符串都是第一次出現的   exist = false;   // 補充之前的信息   for (int j = 0; j <= i; j++) {   setTrue(indexs[j]);   }  }  } else {  setTrue(index);  } }  return exist;  }  private void checkNeedClear() { if (autoClearRate != null) {  if (getUseRate() >= autoClearRate) {  synchronized (this) {   if (getUseRate() >= autoClearRate) {   notebook.clear();   useCount.set(0);   }  }  } } }  public void setTrue(int index) { useCount.incrementAndGet(); notebook.set(index, true); }  private int hash(String data, int seeds) { char[] value = data.toCharArray(); int hash = 0; if (value.length > 0) {   for (int i = 0; i < value.length; i++) {  hash = i * hash + value[i];  } }  hash = hash * seeds % size; // 防止溢出變成負數 return Math.abs(hash); }  public double getUseRate() { return (double) useCount.intValue() / (double) size; }  public void saveFilterToFile(String path) { try (ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream(path))) {  oos.writeObject(this); } catch (Exception e) {  throw new RuntimeException(e); }  }  public static BloomFileter readFilterFromFile(String path) { try (ObjectInputStream ois = new ObjectInputStream(new FileInputStream(path))) {  return (BloomFileter) ois.readObject(); } catch (Exception e) {  throw new RuntimeException(e); } }  /** * 清空過濾器中的記錄信息 */ public void clear() { useCount.set(0); notebook.clear(); }  public MisjudgmentRate getRate() { return rate; }  /** * 分配的位數越多,誤判率越低但是越占內存 *  * 4個位誤判率大概是0.14689159766308 *  * 8個位誤判率大概是0.02157714146322 *  * 16個位誤判率大概是0.00046557303372 *  * 32個位誤判率大概是0.00000021167340 *  * @author lianghaohui * */ public enum MisjudgmentRate { // 這里要選取質數,能很好的降低錯誤率 /**  * 每個字符串分配4個位  */ VERY_SMALL(new int[] { 2, 3, 5, 7 }), /**  * 每個字符串分配8個位  */ SMALL(new int[] { 2, 3, 5, 7, 11, 13, 17, 19 }), // /**  * 每個字符串分配16個位  */ MIDDLE(new int[] { 2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47, 53 }), // /**  * 每個字符串分配32個位  */ HIGH(new int[] { 2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47, 53, 59, 61, 67, 71, 73, 79, 83, 89, 97,  101, 103, 107, 109, 113, 127, 131 });  private int[] seeds;  private MisjudgmentRate(int[] seeds) {  this.seeds = seeds; }  public int[] getSeeds() {  return seeds; }  public void setSeeds(int[] seeds) {  this.seeds = seeds; }  }  public static void main(String[] args) { BloomFileter fileter = new BloomFileter(7); System.out.println(fileter.addIfNotExist("1111111111111")); System.out.println(fileter.addIfNotExist("2222222222222222")); System.out.println(fileter.addIfNotExist("3333333333333333")); System.out.println(fileter.addIfNotExist("444444444444444")); System.out.println(fileter.addIfNotExist("5555555555555")); System.out.println(fileter.addIfNotExist("6666666666666")); System.out.println(fileter.addIfNotExist("1111111111111")); fileter.saveFilterToFile("C://Users//john//Desktop//1111//11.obj"); fileter = readFilterFromFile("C://Users//john//Desktop//111//11.obj"); System.out.println(fileter.getUseRate()); System.out.println(fileter.addIfNotExist("1111111111111")); }}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久这里只有精品99| 国产成人拍精品视频午夜网站| 日韩av日韩在线观看| 久久久成人的性感天堂| 亚洲欧美日韩国产精品| 一区二区三区视频观看| 精品视频久久久久久| 国产精品999| 精品二区三区线观看| 韩国美女主播一区| 国产精欧美一区二区三区| 国产日韩精品电影| 日韩在线免费av| 国产极品jizzhd欧美| 日韩av免费观影| 欧美在线一级va免费观看| 国产专区欧美专区| 国产精品欧美激情在线播放| 欧美大码xxxx| 久久精品福利视频| 欧美在线精品免播放器视频| 日韩欧美国产高清91| 久久五月天色综合| 国产成人综合久久| 欧亚精品在线观看| 91香蕉嫩草神马影院在线观看| 午夜精品三级视频福利| 久久久久久久久久久网站| 亚洲深夜福利网站| 亚洲精品之草原avav久久| 亚洲综合第一页| 国产成人精品优优av| 成人午夜黄色影院| 这里只有精品在线观看| 国产精品极品尤物在线观看| 国产第一区电影| 国产成人免费av电影| 国产欧美久久一区二区| 日韩av一区在线| 91久久在线观看| 国产亚洲激情在线| 亚洲一级黄色av| 国产精品美腿一区在线看| 久久精品电影网站| 国产精品一区久久久| 波霸ol色综合久久| 亚洲图片欧洲图片av| 秋霞午夜一区二区| 国产精品爽黄69天堂a| 在线播放国产一区二区三区| 激情av一区二区| 日韩一区二区久久久| 欧美日韩国产123| 亚洲国产欧美自拍| 欧美巨猛xxxx猛交黑人97人| 欧美在线精品免播放器视频| 欧美性xxxxxx| 亚洲第一av网站| 亚洲一区二区久久久久久久| 亚洲电影免费观看高清完整版在线观看| 国产精品电影久久久久电影网| 久久人人爽国产| 欧美黑人性视频| 成人a级免费视频| 视频在线观看一区二区| 久久夜色精品国产亚洲aⅴ| 欧美日韩ab片| 日韩大片免费观看视频播放| 欧美在线一级视频| 91美女福利视频高清| 国产精品美女在线观看| 亚洲最新视频在线| 青青草成人在线| 欧美精品在线看| 大伊人狠狠躁夜夜躁av一区| 日韩免费av在线| 欧美—级a级欧美特级ar全黄| 精品国产精品自拍| 97婷婷大伊香蕉精品视频| 国产精品福利在线观看| www.欧美精品| 久久亚洲国产精品| 国产亚洲精品一区二区| 日韩中文字幕久久| 国产精品成人观看视频国产奇米| 国产在线观看91精品一区| 久久国产精品视频| 欧美多人乱p欧美4p久久| 亚洲性夜色噜噜噜7777| 精品国产欧美一区二区三区成人| 亚洲欧洲自拍偷拍| 欧美一级大片在线免费观看| 亚洲最大福利视频网站| 欧美激情亚洲一区| 久久久久国产精品免费| 国产91在线播放九色快色| 一本一本久久a久久精品牛牛影视| 亚洲成人网久久久| 91av视频在线播放| 亚洲国产中文字幕久久网| 国产精品国产三级国产aⅴ浪潮| 日韩av在线影院| 国产精品一香蕉国产线看观看| 久久久久久亚洲精品| 亚洲2020天天堂在线观看| 欧美极品欧美精品欧美视频| 黑丝美女久久久| 日韩成人中文电影| 成人日韩av在线| 亚洲精品动漫久久久久| 国产欧美久久久久久| 国产激情视频一区| 一区二区亚洲欧洲国产日韩| 亚洲xxxx妇黄裸体| 国产mv免费观看入口亚洲| 亚洲精品之草原avav久久| 欧美日韩激情美女| 中文字幕一区二区三区电影| 欧美巨猛xxxx猛交黑人97人| 国产精品嫩草影院久久久| 亚洲免费av网址| 91成人国产在线观看| 国产精品久久久久久av| 久久资源免费视频| 精品久久久久久久久中文字幕| 亚洲欧美精品伊人久久| 91精品国产高清久久久久久久久| 97精品国产97久久久久久春色| 日本精品视频在线播放| 亚洲成年人在线播放| 久久精品人人做人人爽| 国产午夜精品美女视频明星a级| 国产精品免费电影| 久久久免费在线观看| 亚洲精选在线观看| 性色av一区二区咪爱| 91香蕉嫩草神马影院在线观看| 欧美精品一区在线播放| 亚洲精品成a人在线观看| 色综合久久久久久中文网| 亚洲性生活视频在线观看| 国产成人精品av在线| 亚洲激情免费观看| 国产精品视频自拍| 国产丝袜一区视频在线观看| 日韩精品免费在线视频| 国产又爽又黄的激情精品视频| 成人精品aaaa网站| 91免费精品国偷自产在线| 国产精品极品美女在线观看免费| 欧美电影电视剧在线观看| 麻豆国产精品va在线观看不卡| 国产精品国产三级国产aⅴ浪潮| 国产精品久久91| 久久精品视频在线播放| 亚洲性无码av在线| 欧美日韩视频免费播放| 色婷婷综合成人av| 久久精品免费播放| 亚洲国产中文字幕在线观看| 欧美激情中文字幕乱码免费| 国产精品视频男人的天堂| 97久久精品人搡人人玩| 欧美日韩国产精品一区二区不卡中文|