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

牽著老婆滿街逛

嚴以律己,寬以待人. 三思而后行.
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 楊粼波 閱讀(1949) 評論(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>
            欧美 日韩 国产在线| 久久综合给合| 国产精品久在线观看| 亚洲婷婷在线| 久久精品成人欧美大片古装| 国产亚洲综合在线| 美女亚洲精品| 亚洲精品日产精品乱码不卡| 亚洲一区免费看| 国产日产高清欧美一区二区三区| 欧美在线观看一区二区三区| 欧美丰满少妇xxxbbb| 亚洲日本欧美| 国产精品毛片a∨一区二区三区| 亚洲永久在线观看| 快射av在线播放一区| 日韩亚洲欧美成人| 国产精品入口麻豆原神| 久久久久久电影| 亚洲美女黄色片| 久久精品日产第一区二区三区| 在线播放日韩欧美| 欧美四级伦理在线| 久久久最新网址| 一区二区三区视频在线看| 久久免费午夜影院| 一本色道久久综合狠狠躁篇的优点 | 亚洲性人人天天夜夜摸| 久久人人爽国产| 一区二区三区国产精华| 国产日韩欧美日韩大片| 欧美肥婆bbw| 欧美一区二区三区的| 亚洲国产一区二区三区a毛片 | 欧美成人黄色小视频| 亚洲视频999| 亚洲大胆人体在线| 国产精品三级视频| 欧美精品久久久久久久久老牛影院| 亚洲综合电影| 亚洲日本欧美在线| 玖玖在线精品| 久久国产精品久久精品国产| 日韩视频二区| 亚洲国产aⅴ天堂久久| 国产精品一二| 欧美日韩国产一中文字不卡| 久久久www| 欧美伊人久久| 亚洲欧美日韩国产一区二区三区 | 亚洲欧美在线观看| 一二三区精品福利视频| 亚洲国产高清一区| 国内揄拍国内精品久久| 国产精品美女一区二区| 亚洲一区日韩| 国产亚洲欧美一区| 国产精品久久亚洲7777| 欧美α欧美αv大片| 久久精精品视频| 亚洲欧美色婷婷| 亚洲视频在线观看网站| 99riav久久精品riav| 亚洲国产日韩一级| 欧美激情视频一区二区三区在线播放| 久久精品免费播放| 欧美在线免费观看| 欧美一级一区| 欧美一区观看| 欧美一区二区三区久久精品| 亚洲欧美区自拍先锋| 亚洲女ⅴideoshd黑人| 亚洲视频观看| 一区二区三区国产在线观看| 日韩视频精品在线| 一区二区三区精密机械公司 | 国产综合色在线| 国产三级欧美三级| 国产麻豆精品theporn| 国产精品一区二区三区久久久| 国产精品a久久久久| 国产精品久久久久久久久久妞妞| 国产精品高精视频免费| 国产精品国产精品| 国产精品亚洲精品| 国产婷婷色一区二区三区四区| 国产精品视频最多的网站| 国产精品一区二区三区免费观看| 国产酒店精品激情| 狠狠色综合色区| 亚洲国产另类 国产精品国产免费| 亚洲国产精品久久久久秋霞不卡| 亚洲第一中文字幕在线观看| 亚洲二区视频| 一区二区av在线| 亚洲一区二区三区精品视频| 午夜综合激情| 久久夜色精品国产| 欧美高清不卡在线| 亚洲理论在线| 午夜精品成人在线| 久久综合五月天婷婷伊人| 欧美乱妇高清无乱码| 欧美日韩中文在线| 国产亚洲一区二区三区在线播放| 在线观看日韩av电影| 夜夜嗨av一区二区三区网站四季av | 国产精品欧美日韩久久| 国产在线欧美日韩| 亚洲激情成人| 午夜视频在线观看一区| 免费成人高清| 亚洲午夜精品国产| 久久综合久久综合久久综合| 欧美日韩一区在线视频| 激情综合色综合久久| 在线亚洲欧美视频| 久久天天综合| 中文av字幕一区| 久久美女性网| 国产精品入口尤物| 亚洲精品日本| 老鸭窝毛片一区二区三区| 亚洲另类春色国产| 久久综合九色综合久99| 国产精品久久久久久久久久久久久久 | 久久久久国产精品一区| 亚洲精品国产精品久久清纯直播| 午夜一区二区三视频在线观看| 乱人伦精品视频在线观看| 国产精品免费aⅴ片在线观看| 在线观看一区二区精品视频| 欧美一区二区三区免费视频| 亚洲欧洲一区二区三区在线观看| 午夜一区在线| 欧美午夜影院| 日韩一级免费观看| 欧美.日韩.国产.一区.二区| 亚洲一区二区在线播放| 欧美激情1区2区| 亚洲成色精品| 久久蜜桃精品| 亚洲欧美国产毛片在线| 欧美区一区二| 亚洲靠逼com| 欧美第一黄网免费网站| 欧美一区二区成人6969| 国产精品家教| 亚洲尤物影院| 亚洲精品一区二| 欧美大尺度在线| 亚洲国语精品自产拍在线观看| 久久久免费精品| 性8sex亚洲区入口| 国产精品欧美日韩| 午夜精品在线视频| 99精品视频一区| 欧美三级网址| 亚洲在线1234| 国产精品99久久久久久久久| 欧美日韩国产bt| 中日韩视频在线观看| 亚洲理论电影网| 欧美视频中文一区二区三区在线观看| 亚洲乱码视频| 亚洲精品久久久久久久久久久久久| 欧美mv日韩mv国产网站app| 在线看片第一页欧美| 美女在线一区二区| 久久综合狠狠综合久久激情| 亚洲国产高清aⅴ视频| 亚洲第一综合天堂另类专| 免费亚洲电影在线| 亚洲靠逼com| 一区二区三区免费观看| 国产精品久久久久久久久久ktv | 99在线精品视频| 国产精品久久久久aaaa樱花| 小辣椒精品导航| 久久精品国产v日韩v亚洲| 一区免费观看视频| 亚洲大胆美女视频| 欧美日韩免费高清| 欧美一区二区黄| 久久精品国产77777蜜臀| 亚洲高清网站| 一本久道综合久久精品| 国产精品亚洲片夜色在线| 久久天天狠狠| 欧美精品激情在线| 亚洲综合精品自拍| 久久精品72免费观看| 亚洲精品视频在线播放| 亚洲香蕉网站| 伊人激情综合| 99精品99| 激情久久综合| 一区二区三区不卡视频在线观看| 国产亚洲女人久久久久毛片| 欧美成人免费视频|