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

牽著老婆滿街逛

嚴以律己,寬以待人. 三思而后行.
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>
            欧美在线亚洲在线| 久久精品国产久精国产思思| 欧美激情在线| 另类综合日韩欧美亚洲| 亚洲国产一区在线| 91久久精品国产91性色tv| 老司机一区二区| 日韩一二三在线视频播| 日韩午夜精品| 国产精品一区二区在线| 久久九九热免费视频| 国产精品久线观看视频| 久久女同互慰一区二区三区| 狠狠色综合网站久久久久久久| 久久久久一区二区三区| 久久综合一区二区| 99热精品在线观看| 亚洲一区日韩| 亚洲丶国产丶欧美一区二区三区| 91久久久久| 国产精品视频导航| 欧美成人一区在线| 国产精品成人在线观看| 久久本道综合色狠狠五月| 久久婷婷国产麻豆91天堂| 一区二区日韩| 久久国产精品久久久久久| 亚洲国产经典视频| 亚洲网站在线| 91久久精品美女| 亚洲一区免费看| 日韩一区二区精品葵司在线| 午夜精品久久久久久久蜜桃app| 亚洲国产美国国产综合一区二区| 中国亚洲黄色| 亚洲精品网址在线观看| 欧美一级一区| 亚洲午夜激情在线| 麻豆免费精品视频| 欧美在线资源| 欧美视频在线观看视频极品| 久久综合狠狠综合久久激情| 国产精品爱久久久久久久| 欧美激情在线播放| 狠狠干综合网| 欧美一区二区精品久久911| 亚洲美女毛片| 裸体歌舞表演一区二区| 欧美中文字幕视频| 欧美日韩免费高清一区色橹橹| 久久影院午夜片一区| 国产精品久久久久毛片大屁完整版 | 国产日韩欧美中文| 亚洲日本成人| 亚洲人成高清| 久久在线免费| 久色成人在线| 国自产拍偷拍福利精品免费一| 一区二区三区高清| 99在线热播精品免费99热| 鲁大师影院一区二区三区| 久久亚洲一区二区| 国内精品久久国产| 久久se精品一区二区| 久久国产主播| 国产中文一区| 午夜精品久久久久久久99热浪潮 | 久久国产乱子精品免费女| 欧美日韩综合久久| 日韩天堂av| 亚洲在线观看免费| 国产精品呻吟| 欧美在线资源| 蜜桃av噜噜一区| 亚洲人体1000| 欧美日韩高清在线一区| 在线亚洲精品| 亚洲欧美日韩精品久久久久| 国产精品狼人久久影院观看方式| 夜夜嗨av一区二区三区中文字幕 | 一区二区三区日韩精品视频| 一区二区三区日韩精品| 欧美三日本三级少妇三2023| 一区二区电影免费观看| 午夜激情综合网| 国产一区二区三区高清在线观看| 久久国产乱子精品免费女| 蜜乳av另类精品一区二区| 亚洲精品社区| 国产精品区免费视频| 久久精品人人做人人综合| 欧美高清视频| 亚洲欧美乱综合| 伊人久久噜噜噜躁狠狠躁| 欧美大片在线观看一区| 一区二区三区 在线观看视频| 亚洲欧美中文日韩v在线观看| 黄色成人在线网址| 欧美精品一卡| 欧美一区二区三区日韩| 欧美激情一区二区| 午夜精品久久久久久久99热浪潮| 好看的日韩视频| 欧美精品在线网站| 久久国产精品毛片| 日韩亚洲精品电影| 老**午夜毛片一区二区三区| 亚洲免费观看高清完整版在线观看熊 | 亚洲欧美日本国产有色| 麻豆精品一区二区综合av| 一区二区三区欧美成人| 韩日成人在线| 国产精品女主播| 蜜桃久久精品一区二区| 亚洲无人区一区| 亚洲级视频在线观看免费1级| 午夜一区不卡| 一本不卡影院| 亚洲精品乱码久久久久久日本蜜臀 | 亚洲三级视频在线观看| 国产欧美日韩视频一区二区| 欧美成人午夜影院| 久久国产黑丝| 亚洲一区二区三区777| 最新热久久免费视频| 久久先锋影音| 欧美资源在线观看| 亚洲一区二区在线观看视频| 亚洲国产影院| 影音先锋亚洲一区| 国产在线高清精品| 国产精品自拍三区| 欧美私人啪啪vps| 欧美福利电影在线观看| 久久久人成影片一区二区三区| 亚洲欧美国产77777| 在线视频亚洲| 国产精品99久久久久久有的能看| 亚洲国产精品久久精品怡红院| 久久综合久久88| 久久久午夜精品| 久久天堂成人| 另类春色校园亚洲| 美女精品视频一区| 美玉足脚交一区二区三区图片| 久久理论片午夜琪琪电影网| 久久久精品五月天| 久久久精品日韩| 蜜臀av一级做a爰片久久| 久久久成人网| 蜜臀久久久99精品久久久久久 | 久久亚洲春色中文字幕| 久久精彩视频| 久久久久国产精品人| 久久久一区二区| 久色婷婷小香蕉久久| 欧美二区不卡| 亚洲精品中文字幕女同| 洋洋av久久久久久久一区| 亚洲夜晚福利在线观看| 亚洲欧美日韩精品久久亚洲区 | 亚洲桃色在线一区| 午夜伦理片一区| 久久九九热re6这里有精品| 久久嫩草精品久久久精品一| 免费成人黄色| 国产精品国产三级国产普通话蜜臀| 国产精品伦一区| 极品少妇一区二区三区| 日韩午夜激情av| 欧美一进一出视频| 牛牛精品成人免费视频| 99re6这里只有精品| 午夜亚洲性色福利视频| 裸体丰满少妇做受久久99精品| 欧美日韩蜜桃| 激情久久久久久| 一区二区av| 久久深夜福利| 99精品99久久久久久宅男| 欧美一区高清| 欧美精品一区二区视频| 国产九九视频一区二区三区| 亚洲国产第一页| 亚洲欧美日韩视频二区| 欧美www在线| 亚洲免费视频网站| 欧美国产亚洲精品久久久8v| 国产精品一区二区久久精品| 亚洲黄色三级| 久久精品亚洲一区二区| 亚洲人成精品久久久久| 欧美在线一级视频| 欧美亚州一区二区三区| 亚洲精品1区| 久久综合导航| 午夜亚洲一区| 国产精品久久777777毛茸茸| 91久久久久久久久久久久久| 久久精品国产一区二区三区免费看|