ELF哈希技术

  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;  
}  


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值