ELFhash详情见点击打开链接
代码如下:
unsigned int ELFhash(char *str) { unsigned int hash=0; unsigned int x=0; while(*str) { hash=(hash<<4)+*str; if((x=hash & 0xf0000000)!=0) { hash^=(x>>24); //影响5-8位,杂糅一次 hash&=~x; //清空高四位 } str++; } return (hash & 0x7fffffff); }
或则
int ELFhash(char *key){ unsigned long h = 0; unsigned long x = 0; while (*key) { h = (h << 4) + (*key++); //h左移4位,当前字符ASCII存入h的低四位 if ((x = h & 0xF0000000L) != 0) { //如果最高位不为0,则说明字符多余7个,如果不处理,再加第九个字符时,第一个字符会被移出 //因此要有如下处理 h ^= (x >> 24); //清空28~31位 h &= ~x; } } return h % HASH_BASE; }