百科问答小站 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合并,就是为了最大程度上避免碰撞。




  

相关话题

  为什么听说过 JVM 调优,却没听说过 CLR 调优? 
  object是引用类型吗? 
  dynamic 定义类型指向GroupedEnumrable ,遍历取key为什么报异常? 
  如何评价微软发布的 Xbox 新主机 Project Scarlett ? 
  如何在西雅图认识工作的中国男生? 
  C# 的匿名类型为什么要限制属性为只读呢? 
  如何评价微软正在开发的人工智能编程软件 DeepCoder? 
  如何获得高并发的经验? 
  C「带坏了」多少程序语言的设计? 
  求助,大一学Java还是C#? 

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





© 2025-02-20 - tinynew.org. All Rights Reserved.
© 2025-02-20 - tinynew.org. 保留所有权利