ELF Hash算法

ELFhash函数在UNIX系统V 版本4中的“可执行链接格式”( Executable and Linking Format,即ELF )中会用到,ELF文件格式用于存储可执行文件与目标文件。ELFhash函数是对字符串的散列。它对于长字符串和短字符串都很有效,字符串中每个字符都有同样的作用,它巧妙地对字符的ASCII编码值进行计算,ELFhash函数对于能够比较均匀地把字符串分布在散列表中。


int ELFHash(char *str,long hash_table_size){
          unsigned int hash=0;
          unsigned int x=0;
          while(*str){
               hash=hash<<4+(*str++);//将hash值左移4位后加上字符ascii
               x=hash&0xF0000000;
               if(x){//因为下一步仍要左移4位,所以如果高4位不为0,进行下面处理,防止丢失信息
                     hash^=x>>24;//将高4位与5~8位异或
                     hash&=~x;//清除最高四位
               }
                return hash%hash_table_size;//对哈希表大小取余
           }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值