FNV哈希算法
FNV哈希算法是一种高离散性的哈希算法,特别适用于哈希非常相似的字符串,例如:URL,IP,主机名,文件名等。
该算法实现简单,特别适合互联网行业。
但该算法也有几个缺点
1. 不适用于加密,因为其执行效率高,容易攻击;
2. 由于hash结果是按位异或和乘积的,如果任何一步出现0,则结果可能会造成冲突;
FVN哈希算法支持多种位的哈希算法,下面是一个32位FVN哈希算法的实现:
class FNV32Hash { private static final long OFFSET_BASIS = 2166136261L;// 32位offset basis private static final long PRIME = 16777619; // 32位prime public static long hash(byte[] src) { long hash = OFFSET_BASIS; for (byte b : src) { hash ^= b; hash *= PRIME; } return hash; } }
代码中的OFFSET_BASIS,PRIME是32位的,不同的位数是用一个算法算出的常量,具体参考:
http://www.isthe.com/chongo/tech/comp/fnv/
相关推荐
bluewelkin 2020-08-17
数据与算法之美 2020-05-05
rein0 2020-02-03
nongfusanquan0 2020-10-28
tuonioooo 2020-10-27
xayddxjsjxywuhui 2020-07-20
luotuo 2020-06-26
清溪算法君老号 2020-06-25
dushine00 2020-06-05
sunjunior 2020-04-23
Oudasheng 2020-04-11
枫叶上的雨露 2020-03-07
码墨 2020-01-18
lixiaotao 2020-01-01
Happyunlimited 2019-12-11
yongchao0 2019-11-18
thefutureIwant 2019-11-04
蜗牛慢爬的李成广 2019-10-02
KDF000 2019-10-18