繁体   English   中英

如何在重写GetHashCode()的类型上使用Object.GetHashCode()

[英]How to use Object.GetHashCode() on a type that overrides GetHashCode()

我有一个实现IEquatable <>的类A,使用它的字段(例如,Ab和Ac)来实现/重写Equals()并覆盖GetHashCode(),并且99%的时候一切正常。 A类是层次结构(B类,C类)的一部分,它们都从接口D继承; 它们都可以一起存储在字典中,因此当它们都带有自己的默认Equals()/ GetHashCode()时很方便。

然而,在构建AI时,有时需要做一些工作来获得Ab和Ac的值; 当发生这种情况时,我想存储对正在构建的实例的引用。 在这种情况下,我不想使用A提供的默认Equals()/ GetHashCode()覆盖。因此,我正在考虑实现一个ReferenceEqualityComparer,这意味着强制使用Object的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 <>,但我希望得到不同的答案。

谢谢

对于自然匹配object.ReferenceEqualsRuntimeHelpers.GetHashCode

有关完整详细信息和ObjectReferenceEqualityComparer<T>的实现,请参阅此问题的答案: 使用ReferenceEquals内置IEqualityComparer<T>

通过interop调用CLR的基本实现: Object.GetHashCode()的默认实现

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM