青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

牽著老婆滿街逛

嚴以律己,寬以待人. 三思而后行.
GMail/GTalk: yanglinbo#google.com;
MSN/Email: tx7do#yahoo.com.cn;
QQ: 3 0 3 3 9 6 9 2 0 .

Google Sparse Hash

Google Sparsehash 包
實現背景:
該包由2種類型和HashTable實現組成。
Sparse 設計的實現過程中考慮的是空間優先;dense 設計上考慮的是時間優先。設計的注重點不一樣,所以實現也不一樣。為了和通用的STL相適應,每一種實現提供了hash-map和Hash-set2種封裝方式。



在使用Hash_map和Hash_set的過程中是不需要安裝STL庫的,google提供了整個的實現過程。Google在實現的過程中大量使用了模板和泛型編程。

實現特點:
1。這個庫提供了內存中Hash tables的一種實現,同時提供了持久化存儲的能力。實現上盡可能快,可移植和小。 實現這些目標使用了Knuth在<<計算機程序設計藝術 第三卷>>中提到的 內部探測散列算法(具體Hash函數的實現可以參考http://burtleburtle.net/bob/hash/evahash 和 http://burtleburtle.net/bob/c/lookup2.c)。與開放鏈Hash算法不同,它不需要指向每個元素的指針項,在實踐中仍然達到了常數級的查找時間。
2.為了節省空間,在插入Hash table的過程中,無論是Key還是data使用Union方式:如果Key或data很小,就直接存儲,否則就存取一個指針。
為了便于存取Key和data,可以使用2個宏 KEY_PTR和PTR_KEY在參數和指針實際所指的數據之間轉換比如:

     char key[] = "ab", *key2;
      HTItem *bck; HashTable *ht;
      HashInsert(ht, PTR_KEY(ht, key), 0);
      bck = HashFind(ht, PTR_KEY(ht, "ab"));
      key2 = KEY_PTR(ht, bck->key);

主要接口:
這個Hash table的實現支持的主要接口如下:


1. HashTable *AllocateHashTable(int cchKey, int fSaveKeys)

   功能:分配一個Hashtable的結構并且返回它
參數:    cchKey: 為正數時候,表明每個Key是固定長度的;為0表明Key是一個以\0結束的固定長度的字符串。
       fSaveKey: 通過是需要調用者分配Key的空間,如果設置為1,會Copy一個Key。

2.     ClearHashTable(HashTable *ht)
功能:移除 hashtable的所有元素;

3.   void FreeHashTable(HashTable *ht)
功能: 釋放 hashtable使用的內存

4.    HTItem *HashFind(HashTable *ht, ulong key)
         功能:查詢Hashtable,找到返回該元素,否則為空;
5.     HTItem *HashFindLast(HashTable *ht)
     功能:返回最后查找過的的元素
6     HTItem *HashFindOrInsert(HashTable *ht, ulong key, ulong dataInsert)
           功能:查找指定的Key的元素,不在就插入。 

7.   HTItem *HashFindOrInsertItem(HashTable *ht, HTItem *pItem)
          功能:插入一個Key/data對,是否覆蓋已經存在的元素由 SAMEKEY_OVERWRITE標記設定。

9     HTItem *HashInsert(HashTable *ht, ulong key, ulong data)
             功能: -- 插入 key/data as an HTItem.
10    int HashDelete(HashTable *ht, ulong key)
          功能:   -- 移除一個制定Key的元素,成功返回1,否則不存在返回0
11     int HashDeleteLast(HashTable *ht)
       功能: -- 刪除最近查詢過的元素.

12     HTItem *HashFirstBucket(HashTable *ht)
             功能-- 用來遍歷hashtable的桶, 遍歷過程中不要做插入和刪除操作;
13    HTItem *HashNextBucket(HashTable *ht)
                  -- RETURNS NULL at the end of iterating.

14     int HashSetDeltaGoalSize(HashTable *ht, int delta)
                  功能:一次性批量插入數據;

15    void HashSave(FILE *fp, HashTable *ht, int (*dataWrite)(FILE *, char *))
                 
          功能:將整個Hash表的內容保存在文件中。如果數據域是一個指針或者復雜的數據結構,需要傳遞一個函數指針將文件指針作為參數,此時可以寫入你想寫入的東西,函數返回寫入的字節數。如果數據域是整數,不需要傳函數指針。
        
16    static HashTable *HashDoLoad(FILE *fp, char * (*dataRead)(FILE *, int),
        HashTable *ht)

          功能: --裝入Hash表. 他需要一個函數來讀取一個文件的結構和結構的大小。功能與 HashSave對應。
17     HashTable *HashLoadKeys(FILE *fp, char * (*dataRead)(FILE *, int))
               功能:        -- 與 HashLoad(),不同 只有必要的時候才從磁盤Load相應的數據.這種方法可以節省內存 。
注意:在裝入數據的時候不應該插入和刪除數據。


功能擴展:

這個HashTable實現沒有使用共享內存的方式,我們可以對AllocateHashTable進行簡單改寫使用共享內存的方式;另外這個Hashtable沒有提供自動淘汰節點的功能,可以增加LRU,對訪問節點的計數和時間統計,在無法繼續插入新的節點時候觸發淘汰操作。 

posted on 2010-10-04 06:58 楊粼波 閱讀(5377) 評論(1)  編輯 收藏 引用

評論

# re: Google Sparse Hash 2015-12-18 00:35 問問

在codeblocks里如何使用Google sparse hash 求指導  回復  更多評論   

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久综合福利| 亚洲精品九九| 欧美亚洲视频| 亚洲欧美日韩视频一区| 欧美精品免费在线观看| 新67194成人永久网站| 欧美剧在线观看| 91久久国产综合久久蜜月精品 | 欧美亚洲在线| 99视频国产精品免费观看| 欧美精品色网| 国产精品五月天| 在线电影院国产精品| 欧美有码视频| 亚洲欧美视频一区| 久久不见久久见免费视频1| 99re6这里只有精品| 久久久免费av| 国产精品高清免费在线观看| 99精品国产99久久久久久福利| 亚洲高清免费| 欧美精品亚洲精品| 亚洲一区bb| 亚洲视频一区二区在线观看| 美女脱光内衣内裤视频久久网站| 亚洲高清免费| 亚洲第一精品久久忘忧草社区| 欧美成人自拍视频| 亚洲激情一区二区三区| 亚洲国产一成人久久精品| 欧美黄色精品| 亚洲在线视频观看| 午夜精品在线| 在线日韩欧美| 亚洲精品一区中文| 国产精品青草综合久久久久99 | 欧美日韩一区高清| 久久久久久久999| 激情懂色av一区av二区av| 欧美freesex交免费视频| 蜜桃精品一区二区三区| 宅男噜噜噜66一区二区66| 亚洲制服少妇| 在线成人性视频| 在线视频亚洲欧美| 激情成人av在线| 亚洲国产视频a| 国产精品激情av在线播放| 欧美专区一区二区三区| 美国十次成人| 一区三区视频| 欧美成人一品| 国产精品久久夜| 欧美激情无毛| 国产欧美精品日韩| 亚洲精品黄网在线观看| 国产亚洲精久久久久久| 亚洲另类视频| 激情久久一区| 亚洲天堂免费在线观看视频| 亚洲国产成人久久综合| 一卡二卡3卡四卡高清精品视频| 好吊色欧美一区二区三区四区| 亚洲国产精品欧美一二99| 国产欧美精品日韩精品| 最新国产精品拍自在线播放| 一区二区三区视频在线| 亚洲精品欧美日韩专区| 国产日韩精品一区| 欧美影院在线| 亚洲最新在线| 久久久人成影片一区二区三区 | 欧美成人午夜77777| 欧美视频网址| 91久久精品一区二区别| 国产精品一区在线播放| 欧美风情在线观看| 一本色道久久综合亚洲精品婷婷 | 在线看片欧美| 午夜精品电影| 午夜在线视频一区二区区别| 欧美另类变人与禽xxxxx| 免费短视频成人日韩| 国产农村妇女毛片精品久久莱园子| 亚洲三级免费| 亚洲另类自拍| 午夜精品影院在线观看| 亚洲精品资源| 久久久久免费| 久久在线免费| 久久婷婷蜜乳一本欲蜜臀| 国产精品五区| 亚洲午夜精品久久| 亚洲天堂免费观看| 欧美另类videos死尸| 亚洲人体一区| 一区二区三欧美| 麻豆精品视频在线观看| 久久国产精品一区二区| 国产免费观看久久| 午夜宅男久久久| 久久久精品免费视频| 韩国av一区二区| 久久久精彩视频| 免费观看亚洲视频大全| 亚洲系列中文字幕| 国产精品视频导航| 欧美日本不卡| 国产精品99久久久久久久久久久久 | 欧美尤物一区| 狠狠色丁香婷综合久久| 久久激情五月激情| 欧美大胆a视频| 亚洲日本一区二区| 欧美手机在线视频| 欧美一区三区三区高中清蜜桃| 久久久综合网| 亚洲精品久久久一区二区三区| 欧美激情中文字幕乱码免费| 亚洲精品视频一区| 久久国产精品亚洲77777| 樱桃视频在线观看一区| 欧美激情一区二区三区高清视频| 国产一区二区日韩| 日韩视频在线免费观看| 午夜精品影院| 一区在线观看| 欧美日韩一区二区免费在线观看| 亚洲欧美日韩综合aⅴ视频| 欧美成人嫩草网站| 一区二区三区免费在线观看| 国产欧美一区二区在线观看| 麻豆精品视频在线观看| 中文欧美在线视频| 牛人盗摄一区二区三区视频| 国产美女精品视频| 亚洲免费在线| 久久综合伊人77777麻豆| 亚洲国产成人av在线| 欧美电影免费| 99热在线精品观看| 亚洲人屁股眼子交8| 欧美视频一区二区三区在线观看| 亚洲欧洲午夜| 久久亚洲精品视频| 中文无字幕一区二区三区| 伊人狠狠色丁香综合尤物| 欧美a级片网站| 久久精品视频免费播放| 国产亚洲一区二区三区| 欧美女激情福利| 日韩亚洲一区二区| 亚洲黄色影院| 国产精品99久久久久久有的能看| 欧美性猛交xxxx乱大交蜜桃 | 欧美超级免费视 在线| 欧美一进一出视频| 一本色道久久综合亚洲精品按摩 | 亚洲激情网址| 欧美成人精品在线视频| 一本色道久久综合亚洲精品按摩| 国产精品久线观看视频| 免费不卡在线观看av| 久久精品99| 羞羞答答国产精品www一本 | 亚洲欧美视频一区| 亚洲午夜极品| 亚洲线精品一区二区三区八戒| 日韩视频一区二区在线观看| 在线观看亚洲精品| 亚洲成人资源网| 亚洲国产精品成人| 亚洲国产精品ⅴa在线观看| 亚洲东热激情| 在线观看亚洲视频| 在线成人欧美| 亚洲精品乱码久久久久久按摩观| 国产精品一区二区欧美| 欧美精品一区二区三区蜜臀 | 在线观看日韩一区| 一区二区在线视频播放| 在线视频观看日韩| 亚洲国产三级| 99精品国产在热久久婷婷| 夜夜爽夜夜爽精品视频| 国产区亚洲区欧美区| 国产一区欧美日韩| 亚洲第一精品在线| 亚洲精品视频在线| 亚洲人午夜精品免费| 亚洲一区二区黄色| 午夜精品久久久久久久男人的天堂 | 亚洲国产精品久久久久婷婷884 | 国产精品尤物| 99热免费精品| 亚洲免费伊人电影在线观看av| 亚洲免费在线视频| 久久精品亚洲一区二区三区浴池| 美女免费视频一区| 嫩草伊人久久精品少妇av杨幂|