免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1739 | 回复: 3
打印 上一主题 下一主题

请教elfhash函数能保证不同的输入必定产生不同的输出吗? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-05-22 09:29 |只看该作者 |倒序浏览
大家好,elfhash函数能保证不同的输入必定产生不同的输出吗?我们一个项目中的代码,从代码中看它依赖于此函数来保证不同的字符串输入必定产生不同的输出,我自己感觉这样很不可靠,但自己又不会分析,想请大家帮忙分析一下,谢谢。

unsigned int ELFHash(char* str, unsigned int len)   
{   
    unsigned int hash = 0;   
    unsigned int x    = 0;   
    unsigned int i    = 0;   
      
    for(i = 0; i < len; str++, i++)   
    {   
       hash = (hash << 4) + (*str);         
       if((x = hash & 0xF0000000L) != 0)         
       {  
            hash ^= (x >> 24);   
       }   
       hash &= ~x;   
    }   
      
    return hash;   
}   

论坛徽章:
0
2 [报告]
发表于 2012-05-22 10:30 |只看该作者
当然不可能
结果一共 ~0U 种
~0U + 1 种 str 必然冲突

论坛徽章:
324
射手座
日期:2013-08-23 12:04:38射手座
日期:2013-08-23 16:18:12未羊
日期:2013-08-30 14:33:15水瓶座
日期:2013-09-02 16:44:31摩羯座
日期:2013-09-25 09:33:52双子座
日期:2013-09-26 12:21:10金牛座
日期:2013-10-14 09:08:49申猴
日期:2013-10-16 13:09:43子鼠
日期:2013-10-17 23:23:19射手座
日期:2013-10-18 13:00:27金牛座
日期:2013-10-18 15:47:57午马
日期:2013-10-18 21:43:38
3 [报告]
发表于 2012-05-22 11:48 |只看该作者
不看实现,所有的hash都不能保证这一点

论坛徽章:
0
4 [报告]
发表于 2012-05-22 14:15 |只看该作者
谢谢楼上几位了。2楼的想法很有说服力。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP