Xod*_*rap 5 c# hash hash-code-uniqueness hash-collision
我有以下代码来生成对象的哈希:
public int GetHashCode(MyType obj)
{
return (obj.Prop1.GetHashCode() + obj.Prop2.GetHashCode() + obj.Prop3.GetHashCode()).GetHashCode();
}
Run Code Online (Sandbox Code Playgroud)
即我添加所有属性的哈希码,然后获取此哈希值.
在审查中,一位同事建议这将过于频繁地发生碰撞.我不确定这是真的,因为:
谁是对的?
它是在C#中,以防答案是特定于语言的.
是.
假设Prop1,Prop2等属于类型int.通常只使用较低范围的整数.您的总和方法将比必要时更频繁地发生碰撞.
HasCode 7是7,当int它自己进行散列时非常有意义.但是你的代码是元组<7, 3>,<3, 7>并且<8, 2>都会有相同的哈希.与简单的XOR相同而不是加法.
常见的方法是添加一些(素数)和移位:
public int GetHashCode(MyType obj)
{
int hash = 0;
unchecked
{
hash += 19 * obj.Prop1.GetHashCode();
hash += 31 * obj.Prop2.GetHashCode();
hash += 37 * obj.Prop3.GetHashCode();
}
return hash;
}
Run Code Online (Sandbox Code Playgroud)
数字19,31,37不是太关键.如果您愿意,可以使用OR或XOR代替+.