我有一个实现IEquatable<>的类A,它使用它的字段(比如A.b和A.c)来实现/覆盖Equals()和覆盖GetHashCode(),并且在99%的情况下一切正常。类A是层次结构(类B,C)的一部分,所有这些类都继承自接口D;它们都可以一起存储在一个字典字典中,因此当它们都带有自己的默认Equals()/GetHashCode()时很方便。
然而,在构建A时,我有时需要做一些工作来获取A.b和A.C的值;当发生这种情况时,我希望存储对正在构建的实例的引用。在这种情况下,我不想使用A提供的默认Equals()/GetHashCode()重写。因此,我在考虑实现一个ReferenceEqualityComparer,这意味着强制使用对象的Equals()/GetHashCode():
private class ReferenceEqualityComparer<T> : IEqualityComparer<T>
{
#region IEqualityComparer<T> Members
public bool Equals(T x, T y)
{
return System.Object.ReferenceEquals(x, y);
}
public int GetHashCode(T obj)
{
// what goes here? I want to do something like System.Object.GetHashCode(obj);
}
#endregion
}问题是,由于A覆盖了Object.GetHashCode(),我如何(在A之外)为A的实例调用Object.GetHashCode()?
当然,一种方法是A不实现IEquatable<>,并且总是为我创建的任何字典提供IEqualityComparer<>,但我希望得到一个不同的答案。
谢谢
发布于 2010-03-29 11:16:26
RuntimeHelpers.GetHashCode是object.ReferenceEquals的天然匹配项。
有关详细信息和ObjectReferenceEqualityComparer<T>的实现,请参阅此问题的答案:Built-in IEqualityComparer that uses ReferenceEquals
发布于 2010-03-29 11:13:22
通过互操作调用CLR的基础实现:Default implementation for Object.GetHashCode()
https://stackoverflow.com/questions/2123888
复制相似问题