当然不可能保证唯一,
俩Int32得到一个Int32怎么可能是唯一的。
一般合并哈希就是用异或,,,
而移位相加后再异或是为了避免两个同样的值异或之后数据丢失。
也就是说a^a^b = b,a的信息丢失了。
首先要说的这种hash方法在.net内部不是单独使用的,在同命名空间下,我们可以看到该方法的使用,主要在向量运算中。任何hash都不能保证唯一性,只能最大可能性的避免碰撞
第二,移位和异或是常规的hash实现和合并方法,这点可以google或者参考知乎中的另一篇帖子
到底什么是hash? - 编程第三,循环hash合并,就是为了最大程度上避免碰撞。
本站所有内容均为互联网搜索引擎提供的公开搜索信息,本站不存储任何数据与内容,任何内容与数据均与本站无关,如有需要请联系相关搜索引擎包括但不限于百度,google,bing,sogou 等
© 2025 tinynews.org All Rights Reserved. 百科问答小站 版权所有