Murmurhash介绍与实现
来源:互联网 发布:inpaint mac破解版 编辑:程序博客网 时间:2024/06/10 03:09
Redis在实现字典时用到了两种不同的哈希算法,MurmurHash便是其中一种(另一种是djb),在Redis中应用十分广泛,包括数据库、集群、哈希键、阻塞操作等功能都用到了这个算法。发明算法的作者被邀到google工作,该算法最新版本是MurmurHash3,基于MurmurHash2改进了一些小瑕疵,使得速度更快,实现了32位(低延时)、128位HashKey,尤其对大块的数据,具有较高的平衡性与低碰撞率。
MurmurHash2的实现,可以放到自己的工程中使用。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34
来自CODE的代码片snippet_file_0.txt
MurmurHash3的实现与测试可以见这里google code。
以下是来自google的测试,对8byte对齐的256k数据块进行hashing,硬件平台Intel Core 2 Quad Q9650,3.0ghz,单核运行。
FNV_x86_32 - 554 mb/sec
FNV_x64_32 - 715 mb/sec
SuperFastHash_x86_32 - 1224 mb/sec (1)
SuperFastHash_x64_32 - 1311 mb/sec
Lookup3_x86_32 - 1234 mb/sec
Lookup3_x64_32 - 1265 mb/sec
MurmurHash2_x86_32 - 2577 mb/sec
MurmurHash2_x86_64 - 3352 mb/sec (2)
MurmurHash2_x64_64 - 2857 mb/sec
MurmurHash3_x86_32 - 3105 mb/sec
MurmurHash3_x86_128 - 2684 mb/sec
MurmurHash3_x64_128 - 5058 mb/sec (3)
- Murmurhash介绍与实现
- Murmurhash介绍与实现
- MurmurHash
- MurmurHash
- murmurhash
- murmurhash
- 利用Murmurhash实现Bloom filter(布隆过滤器)
- MurmurHash算法
- MurmurHash算法
- 赫夫曼树介绍与实现
- MurmurHash PK CityHash
- MurmurHash PK CityHash
- MurmurHash PK CityHash
- 红黑树的介绍与实现
- Kruskal算法介绍与实现
- Prim算法介绍与实现
- LRU缓存介绍与实现
- AVL树介绍与实现
- 2.21 只考加法的面试题后续1
- Integer类==与equals区别与使用
- 如何解决Windows10下安装Ubuntu16.04双系统后没有Ubuntu引导
- 新手必备的12款Asset Store插件
- 暗影精灵3开机黑屏解决方案
- Murmurhash介绍与实现
- 天天和树
- IO概要的学习
- 一个python写的XML解析器的简单实现
- 笔试题
- 从零开始前端学习[2]:img标签的使用
- 如何将matlab中的imresize()函数移植到python中
- ndk学习笔记C语言文件加解密
- MYSQL基础命令