百科问答小站 logo
百科问答小站 font logo



.NET类库中HashCodeHelper的实现原理是什么? 第1页

  

user avatar   Ivony 网友的相关建议: 
      

当然不可能保证唯一,

俩Int32得到一个Int32怎么可能是唯一的。



一般合并哈希就是用异或,,,

而移位相加后再异或是为了避免两个同样的值异或之后数据丢失。

也就是说a^a^b = b,a的信息丢失了。


user avatar   xuan-hun 网友的相关建议: 
      

首先要说的这种hash方法在.net内部不是单独使用的,在同命名空间下,我们可以看到该方法的使用,主要在向量运算中。任何hash都不能保证唯一性,只能最大可能性的避免碰撞


第二,移位和异或是常规的hash实现和合并方法,这点可以google或者参考知乎中的另一篇帖子

到底什么是hash? - 编程

第三,循环hash合并,就是为了最大程度上避免碰撞。




  

相关话题

  微软停止对 Windows XP 支持后,继续联网使用会有哪些风险? 
  如何看待微软对「永恒之蓝」事件的处理? 
  如何评价C# 6的新特性? 
  为什么在项目中要尽量避免使用浮点数,不使用浮点数,那该如何计算浮点数? 
  如何评价 ASP.NET vNext? 
  c#中,is或者as做类型转换是否影响效率,有必要缓存吗? 
  如何评价自由软件基金会 FSF 呼吁微软将 Windows 7 系统进行开源? 
  为何我感觉 Visual Studio 很难用? 
  C#的Lambda表达式捕获变量疑问? 
  Windows Phone的流畅是否是因为应用的匮乏和功能的缺失? 

前一个讨论
如何让<fieldset>基于外边框垂直方向对齐,而不是里面的内容底线对齐?
下一个讨论
如何借助服务器,使两个客户端之间建立网络连接?





© 2024-06-03 - tinynew.org. All Rights Reserved.
© 2024-06-03 - tinynew.org. 保留所有权利