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




  

相关话题

  在C#下有什么好办法可以替代if-else和switch-case? 
  Windows 是如何击败竞争对手并统治桌面操作系统的? 
  如何评价微软正式发布的 Surface Laptop 4? 
  微软董事会调查盖茨与一女性员工关系,为什么盖茨突然出现这么多负面新闻?对其个人形象和公司会有哪些影响? 
  如何才能写出没有bug的程序? 
  WPF中如何在Parallel.For中利用Dispatcher.Invoke实时更新进度条? 
  c#关于异步编程? 
  为什么知乎上很多人说 macOS 很好用,而实际其市场占有率只有大约17.7%? 
  苏州微软加班严重吗? 
  如何看待微软校招毁约口头Offer这种情况? 

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





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