开发者

C#: Same Object have to Same HashCode?

Let's assume I h开发者_Python百科ave two objects called K and M

if(K.Equals(M))
{

}

If that's true, K and M always has the same HashCode ?

Or It depends on the programming language ?


The contract for GetHashCode() requires it, but since anyone can make their own implementation it is never guaranteed.

Many classes (especially hashtables) require it in order to behave correctly.

If you are implementing a class, you should always make sure that two equal objects have the same hashcode.

If you are implementing an utility method/class, you can assume that two equal objects have the same hashcode (if not, it is the other class, not yours, that is buggy).

If you are implementing something with security implications, you cannot assume it.


If that's true, K and M always has the same HashCode ?

Yes.

Or rather it should be the case. Consumers of hash codes (eg. containers) can assume that equal objects have equal hash codes, or rather unequal hash codes means the objects are unequal. (Unequal objects can have the same hash code: there are more possible objects than hash codes so this has to be allowed.)

Or It depends on the programming language ?

No


If that's true, K and M always has the same HashCode ?

Yes. Unless they have a wickedly overridden Equals method. But that would be considered broken.

But note that the reverse is not true,
if K and M have the same HashCode it could still be that K.Equals(M) == false


Yes, it should return the same hash code.

I'd say it's language independent. But there's no guaranty as if other programmes has implemented that correctly.

GetHashCode returns a value based on the current instance that is suited for hashing algorithms and data structures such as a hash table. Two objects that are the same type and are equal must return the same hash code to ensure that instances of System.Collections.HashTable and System.Collections.Generic.Dictionary work correctly.


in your application the hashcode has to uniquely identify an instance of the object. this is part of to the .net platform, so, the hashcode value should work regardless of which .net language you are authoring in.


GetHashCode() could return the same hash for different objects. You should use Equals() to compare objects not GetHashCode(), in case when GetHashCode() return the same value - implementation of Equals() should consider another object equality checks.

Hash data structure able to handle such cases by using collision resolution algotithms.

From wikipedia:

Hash collisions are practically unavoidable when hashing a random subset of a large set of possible keys. For example, if 2,500 keys are hashed into a million buckets, even with a perfectly uniform random distribution, according to the birthday problem there is a 95% chance of at least two of the keys being hashed to the same slot.

Therefore, most hash table implementations have some collision resolution strategy to handle such events. Some common strategies are described below. All these methods require that the keys (or pointers to them) be stored in the table, together with the associated values.


It depends on the Equals implementation of the object. It may use GetHashCode under the hood, but it doesn´t have too. So basically if you have an object with a custom Equals implementation the HashCode may be different for both objects.

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜