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/

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值