对ASCII字符的哈希冲突进行测试
Tests of hash collision on ASCII characters
我目前正在为我们的一些后端系统构建缓存系统,这意味着我需要某种类型的哈希表来表示缓存的实体。在这种情况下,我想知道是否有人知道任何测试显示不同的算法和最小的ASCII字符串长度必须引起碰撞?Ie。什么是一个安全的长度(ASCII字符)哈希与一系列函数?
原因当然是我想在大小(缓存将在相对较小的服务器上代表数百万个实体),性能和碰撞安全之间进行最佳权衡。
提前感谢,尼克
如果你想要一个强散列,我建议使用Jenkins散列。这应该不太可能产生冲突。在算法方面,你要找的是雪崩测试
Bob Jenkins的网站上有很多关于这类事情的方便信息。
至于哈希表的大小,我相信Knuth建议它足够大,这样在一个完美的哈希中,表的2/3将被填满,而Jenkins建议最接近2的更大幂
希望这对你有帮助!
相关文章:
- 使用C++库在Android项目中修改gradle中的cmake参数,用于插入指令的测试
- 无法编译 rtmidi 测试 cmidiin.cpp 文件, 非法指令
- 写入位置0x0000000C时发生访问冲突
- 尽管测试成功,CppUnit测试核心仍被丢弃.为什么
- 数据成员SFINAE的C++17测试:gcc vs clang
- GL_SHADERSTORAGE_BUFFER位置是否与其他着色器位置冲突
- 使用cmake从源代码构建MySQL连接器/C++失败(与以前的声明冲突)
- 如何使用重载的相等(==)运算符向测试用例添加描述
- 为什么二进制搜索在我的测试中不起作用
- 从父数组测试用例构造二叉树失败
- 试图对缓存进行跨步测试,但程序并没有结束
- 有什么好的方法可以让系统调用代理允许在单元测试中进行模拟
- OpenGL在启用深度测试时不会丢弃我的碎片
- 引发异常:读取访问冲突**dynamicArray**为0x1118235.发生
- 为测试目标创建具有不同源文件夹的文件
- 在子目录中使用target_sources()命令时用于单元测试(qtest)的项目结构
- VC++本机单元测试,找不到调试符号
- 在项目中使用QT单元测试-主(..)函数冲突
- Boost测试用例从DLL访问冲突
- 对ASCII字符的哈希冲突进行测试