ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

c – std :: hash算法和大小

2019-07-25 11:08:09  阅读:291  来源: 互联网

标签:stdhash c c11 algorithm hash


我正在使用C 11和std :: hash算法.
我想知道,使用了什么实际的哈希实现?
我会假设MD5或SHA,但我不能从互联网中挖掘任何信息.

另外,我想知道散列的实际返回位宽,因为我必须将它存储在MySQL中.

最后,是否最好使用std :: hash,比如说其他一些库如crypto?

解决方法:

为std :: hash选择的算法完全取决于实现.可能既不使用MD5也不使用SHA,因为它们会成为性能杀手.

大多数实现将比上面提到的要简单得多,因为对于std :: hash没有加密要求,而MD5和SHA是为加密目的而开发的.

std :: hash的requirements严格程度要低得多:

>接受Key类型的单个参数.
>返回size_t类型的值,该值表示参数的哈希值.
>调用时不抛出异常.
>对于两个相等的参数k1和k2,std :: hash< Key>()(k1)== std :: hash< Key>()(k2).
>对于不相等的两个不同参数k1和k2,std :: hash< Key>()(k1)== std :: hash< Key>()(k2)的概率应该非常小,接近1.0 /的std :: numeric_limits&LT为size_t&GT :: MAX().

标签:stdhash,c,c11,algorithm,hash
来源: https://codeday.me/bug/20190725/1532401.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有