hash一点笔记

1、关于离散后可逆性

我们都知道hash的一个效果就是不可逆,也就是你无法根据散列后的结果,推导出散列前的数据。
我想这可以用一个公式来理解。

假如,hash是由一个函数 h 计算出来的,那么如果 hash = h(x) 的情况,应该说原来的字符串是可以被反推导出来的。因为这是一个关于 x 的一元一次方程。
例如:
字符串 str = abcdef
hash 方法 = str + 常量A

那么如果我就可以根据 hash 的结果来推导出之前的字符串是什么。

如果 hash 函数是 hash = h(x,y) 的话,也就是变量大于等于两个,那么这是一个一元二次方程,就无法推导出原来的字符串了。
例如:
字符串 str = abcdef
hash 方法 = str + length(str)

这个时候就无法根据 hash 的结果来逆推导了。

2、离散的区间范围

其实离散的区间范围就是 32位二进制 的整数范围,应该也有 64位 整数的。md5 是 4 个 32位整数连起来的字符串,也就是 128位。

3、hash算法的重要性

不仅仅我们在加密用户密码的时候才用到 md5 hash算法,其实 hash 算法是一个非常基础非常重要的知识,hashmap 的构成,一些编程语言的基础,甚至 memcache的 cache 分布方式,都需要 hash 算法来做为基础。

就这些吧,hash算法有很多种,常用的就是 times33 了,而且简单,这样的东西,还是应该经常总结一下。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值