字符串哈希函数ELFHash的理解

unsigned long ElfHash ( const unsigned char *name )

{

    unsigned long   h = 0, g;


    while ( *name )

    {

        h = ( h << 4 ) + *name++;

        if ( g = h & 0xF0000000 )//如果最高位不为0,则说明字符已经7个,如果不处理,再加第八个字符时,第一个字符会被移出

          //因此要有如下处理是每一个字符都对字符串的值进行影响。

            h ^= g >> 24;//将第一个字符去影响后面每一个字符的


        h &= ~g;//清空28到31位。g的28位到31位于h的28位到31位完全相同,且g的其他位完全为0,所以g取反之后,与h相与,之后,

//h的28到31位清空,但是其他位都保留了下来。

    }

    return h;

}



本文转自 神迹难觅 51CTO博客,原文链接:http://blog.51cto.com/ji123/1980789,如需转载请自行联系原作者

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值