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

牽著老婆滿街逛

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

time33 哈希函數,又叫 DJBX33A,Bernstein's hash

轉載自:http://www.cnblogs.com/napoleon_liu/articles/1911571.html

php, apache, perl, bsddb都使用time33哈希.

最簡單的版本

  uint32_t time33(char const *str, int len) 
    

        unsigned 
long  hash = 0
        
for (int i = 0; i < len; i++
            hash 
= hash *33 + (unsigned long) str[i]; 
        }
 
        
return hash; 
    }

 

這個版本最可以體現time33的算法思路,夠簡單。

 

把乘法操作換成位操作

        unsigned long time33(char const *str, int len) 
    

        unsigned 
long  hash = 0
        
for (int i = 0; i < len; i++
            hash 
= ((hash <<5+ hash) + (unsigned long) str[i]; 
        }
 
        
return hash; 
    }
 

59個字符1000 0000次運行(gcc沒有開啟優化,因為開了優化后兩個函數的實際代碼會一樣)

第一個:

real    0m4.389s 
user    0m4.388s 
sys     0m0.000s

 

第二個:

real    0m4.137s 
user    0m4.120s 
sys     0m0.000s

 

 

gcc –O2優化后是

real    0m1.367s 
user    0m1.360s 
sys     0m0.000s

 

 

php版本

 

inline unsigned time33(char const*str, int len) 

     unsigned long hash 
= 5381
     
/* variant with the hash unrolled eight times */ 
     
for (; len >= 8; len -= 8) { 
         hash 
= ((hash << 5+ hash) + *str++
         hash 
= ((hash << 5+ hash) + *str++
         hash 
= ((hash << 5+ hash) + *str++
         hash 
= ((hash << 5+ hash) + *str++
        hash 
= ((hash << 5+ hash) + *str++
        hash 
= ((hash << 5+ hash) + *str++
        hash 
= ((hash << 5+ hash) + *str++
        hash 
= ((hash << 5+ hash) + *str++
    } 
    
switch (len) { 
        
case 7: hash = ((hash << 5+ hash) + *str++/* fallthrough */ 
        
case 6: hash = ((hash << 5+ hash) + *str++/* fallthrough */ 
        
case 5: hash = ((hash << 5+ hash) + *str++/* fallthrough */ 
        
case 4: hash = ((hash << 5+ hash) + *str++/* fallthrough */ 
        
case 3: hash = ((hash << 5+ hash) + *str++/* fallthrough */ 
        
case 2: hash = ((hash << 5+ hash) + *str++/* fallthrough */ 
        
case 1: hash = ((hash << 5+ hash) + *str++break
        
case 0: break
    } 
    
return hash; 

 

59個字符,1000 0000次

real    0m1.088s 
user    0m1.068s 
sys     0m0.000s

 

速度提升主要在循環展開, 對于短字符,這個是不明顯的。

php版本的hash初始值是5381, 這個

 

Magic Constant 5381:

  
1. odd number

  
2. prime number

  
3. deficient number

  
4001/010/100/000/101 b

 

Apache版本

unsigned long time33(char const  *str, int *len) 

    unsigned 
long hash = 0;

    
const char *p=str; 
    
if (*len<=0
        
for(p = str; *p; p++
            hash 
= hash * 33 + *p; 
        }
 
        
*len = p - str; 
    }
 
    
else 
        
int i = *len; 
        
for (p = str;i; i--, p++
            hash 
= hash * 33 + *p; 
        }
 
    }
 
    
return hash; 
}

 

測試結果

real    0m1.418s 
user    0m1.412s 
sys     0m0.004s

 

 

綜上,我的改進版本

#define likely(x) __builtin_expect((x),1) 
#define unlikely(x) __builtin_expect((x),0) 
    
//php版本 
    unsigned long time33(char const *str, int len=-1
    

        unsigned 
long hash = 5381
        
/* variant with the hash unrolled eight times */ 
        
char const *= str; 
        
if (unlikely(len<0)) 
                
for(; *p; p++
                    hash 
= hash * 33 + *p; 
                }
 
                
return hash; 
        }


#define TIME33_HASH_MIXED_CH()  hash = ((hash<<5)+hash) + *p++ 
        
for (; len >= 8; len -= 8
            TIME33_HASH_MIXED_CH(); 
//
            TIME33_HASH_MIXED_CH(); //
            TIME33_HASH_MIXED_CH(); //
            TIME33_HASH_MIXED_CH(); //
            TIME33_HASH_MIXED_CH(); //
            TIME33_HASH_MIXED_CH(); //
            TIME33_HASH_MIXED_CH(); //
            TIME33_HASH_MIXED_CH(); //
       }
 
       
switch (len) 
           
case 7: TIME33_HASH_MIXED_CH(); /* fallthrough */ 
           
case 6: TIME33_HASH_MIXED_CH(); /* fallthrough */ 
           
case 5: TIME33_HASH_MIXED_CH(); /* fallthrough */ 
           
case 4: TIME33_HASH_MIXED_CH(); /* fallthrough */ 
           
case 3: TIME33_HASH_MIXED_CH(); /* fallthrough */ 
           
case 2: TIME33_HASH_MIXED_CH(); /* fallthrough */ 
           
case 1: TIME33_HASH_MIXED_CH(); break
           
case 0break
       }
 
       
return hash; 
   }


#undef TIME33_HASH_MIXED_CH

 

測試結果

real    0m1.072s 
user    0m1.064s 
sys     0m0.000s

測試過, 重復率在 1/2000。

 

為什么是33的倍數, PHP中注釋是

DJBX33A (Daniel J. Bernstein, Times 33 with Addition)
  This 
is Daniel J. Bernstein's popular `times 33' hash function as
  posted by him years ago on comp.lang.c. It basically uses a function
  like ``hash(i) 
= hash(i-1* 33 + str[i]''. This is one of the best
  known hash functions 
for strings. Because it is both computed very
  fast and distributes very well.
  The magic of number 
33, i.e. why it works better than many other
  constants, prime or not, has never been adequately explained by
  anyone. So I 
try an explanation: if one experimentally tests all
  multipliers between 
1 and 256 (as RSE did now) one detects that even
  numbers are not useable at all. The remaining 
128 odd numbers
  (except 
for the number 1) work more or less all equally well. They
  all distribute 
in an acceptable way and this way fill a hash table
  with an average percent of approx. 
86%.
  If one compares the Chi
^2 values of the variants, the number 33 not
  even has the best value. But the number 
33 and a few other equally
  good numbers like 
173163127 and 129 have nevertheless a great
  advantage to the remaining numbers 
in the large set of possible
  multipliers: their multiply operation can be replaced by a faster
  operation based on just one shift plus either a single addition
  or subtraction operation. And because a hash function has to both
  distribute good _and_ has to be very fast to compute, those few
  numbers should be preferred and seems to be the reason why Daniel J.
  Bernstein also preferred it.
                   
-- Ralf S. Engelschall rse@engelschall.com

 

 

其它倍數

Ngix使用的是 time31

Tokyo Cabinet使用的是 time37

Bob在他的文章說,小寫英文詞匯適合33, 大小寫混合使用65。time33比較適合的是英文詞匯的hash.


posted on 2011-07-26 15:07 楊粼波 閱讀(1945) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲欧洲日产国产网站| 国模一区二区三区| 一区二区三区欧美在线| 欧美伊人久久大香线蕉综合69| 欧美激情第三页| 亚洲靠逼com| 国产精品色一区二区三区| 午夜亚洲性色福利视频| 欧美mv日韩mv国产网站app| 一本大道久久精品懂色aⅴ| 国产精品二区三区四区| 久久国产精品色婷婷| 葵司免费一区二区三区四区五区| 欧美日韩一区视频| 亚洲欧美在线免费观看| 欧美成人a视频| avtt综合网| 国产专区精品视频| 欧美激情视频在线播放| 亚洲男女毛片无遮挡| 亚洲国产精品成人va在线观看| 一区免费视频| 欧美巨乳在线| 久久精品一本| 日韩一区二区精品葵司在线| 欧美一区二区三区免费在线看 | 欧美精品一区二区在线播放| 一本到高清视频免费精品| 久久一区二区三区四区| 99人久久精品视频最新地址| 国产亚洲精品自拍| 欧美日韩小视频| 久久躁狠狠躁夜夜爽| 亚洲一区二区不卡免费| 亚洲高清免费在线| 久久精品国产精品亚洲精品| 一本大道av伊人久久综合| 狠狠88综合久久久久综合网| 欧美日韩亚洲综合一区| 久久这里有精品视频| 亚洲欧美日韩综合aⅴ视频| 亚洲精品乱码久久久久久蜜桃91| 最新国产乱人伦偷精品免费网站| 久久婷婷久久| 午夜宅男欧美| 国产精品99久久不卡二区| 亚洲日本成人网| 欧美不卡视频一区发布| 久久精彩视频| 性色一区二区| 欧美亚洲综合网| 亚洲一区二区三区久久| 一区二区久久久久| 亚洲全部视频| 亚洲激情视频网站| 在线观看成人小视频| 国产亚洲免费的视频看| 国产美女精品视频| 国产精品夜夜夜| 国产精品av免费在线观看| 欧美精品尤物在线| 欧美精品入口| 欧美美女喷水视频| 欧美日韩一区二区三区在线观看免| 亚洲午夜电影在线观看| 亚洲视频图片小说| 99精品免费网| 一区二区三区免费观看| 亚洲午夜高清视频| 午夜电影亚洲| 午夜精品亚洲| 久久精品国产综合精品| 久久久久久久久久久久久女国产乱 | 久久久国产视频91| 亚洲欧美成人网| 欧美一级精品大片| 久久精品国产欧美亚洲人人爽| 亚洲欧洲另类国产综合| 欧美国产精品久久| 亚洲韩国一区二区三区| 亚洲精品在线免费| 夜夜精品视频一区二区| 亚洲婷婷在线| 欧美一区二区三区在线| 久久久无码精品亚洲日韩按摩| 亚洲最黄网站| 午夜精品影院| 久久婷婷丁香| 欧美日韩国产色综合一二三四 | 亚洲第一精品影视| 在线精品视频一区二区| 亚洲精选视频免费看| 亚洲少妇最新在线视频| 亚洲在线网站| 久久久999精品| 欧美国产一区二区在线观看| 亚洲日本视频| 午夜视频精品| 欧美电影资源| 国产精品永久免费视频| 亚洲国产精品美女| 亚洲综合精品自拍| 另类av一区二区| 99视频一区二区| 久久精品在线播放| 欧美日韩一区二区在线观看视频| 免费永久网站黄欧美| 欧美天堂亚洲电影院在线播放 | 一区二区三区av| 久久国产福利| 欧美~级网站不卡| 一本色道久久精品| 久久久久国产精品午夜一区| 欧美日韩大片| 一区二区三区亚洲| 亚洲欧美日韩国产| 亚洲国产成人久久综合一区| 亚洲欧美高清| 欧美日本国产视频| 激情六月婷婷久久| 亚洲欧美日韩在线不卡| 欧美福利小视频| 午夜一级在线看亚洲| 欧美人成在线| 亚洲高清二区| 久久久久国产精品厨房| aaa亚洲精品一二三区| 久久天堂国产精品| 国产日产亚洲精品| 亚洲欧美激情在线视频| 亚洲成在人线av| 久久久久看片| 国产人成精品一区二区三| 亚洲视频导航| 欧美激情一区二区三区| 久久精品国产99国产精品| 国产精品老女人精品视频| 亚洲人体影院| 模特精品裸拍一区| 欧美在线视频一区二区三区| 国产精品swag| 亚洲一区二区三| 亚洲美女av在线播放| 欧美国产日本| 91久久精品日日躁夜夜躁欧美 | 欧美日韩精品在线视频| 亚洲高清不卡av| 蜜臀久久久99精品久久久久久| 免费在线看成人av| 欧美在线视频观看| 国产精品久久久久久av福利软件| 国产精品夜夜嗨| 亚洲欧美成人一区二区三区| 日韩视频在线播放| 欧美日韩成人综合| 亚洲四色影视在线观看| 99精品视频一区| 欧美性猛交xxxx乱大交蜜桃| 亚洲图片欧美午夜| 亚洲人体偷拍| 欧美日韩亚洲一区二区三区在线观看| 国产精品视频免费| 亚洲男人天堂2024| 亚洲午夜久久久| 国产精品羞羞答答xxdd| 久久精品人人爽| 欧美专区在线观看| 在线播放国产一区中文字幕剧情欧美 | 一本久道久久久| 国产精品久久久久久av下载红粉 | 欧美伊人久久久久久久久影院 | 午夜宅男欧美| 国产伊人精品| 毛片av中文字幕一区二区| 久久成人精品| 亚洲精品永久免费精品| 亚洲美女电影在线| 国产欧美一区二区三区另类精品| 91久久久亚洲精品| 亚洲人成网站影音先锋播放| 欧美日韩国产影院| 欧美一区二区三区播放老司机| 亚洲精品国产品国语在线app | 久久久.com| 91久久线看在观草草青青| 亚洲精品一区二区三区福利| 欧美久久久久久久久| 亚洲欧美国产精品桃花| 欧美在线观看视频| 日韩视频免费观看| 亚洲少妇一区| 亚洲电影在线观看| 99热这里只有精品8| 国产视频一区二区在线观看| 嫩草国产精品入口| 欧美系列精品| 欧美大片国产精品| 欧美视频不卡| 欧美成人免费在线视频| 国产精品爱啪在线线免费观看|