Because you haven't told the generic method that your object implements IEquatable<T>
:
Try now with:
private static bool ObjectsEqual<TValue>(TValue value1, TValue value2)
where TValue : IEquatable<TValue> // IMPORTANT!!!
{
return value1.Equals(value2);
}
In your ObjectsEqual
method you have access only to methods/properties/fields of TValue
that are defined in the object
class plus the methods that are defined in the interfaces/base classes defined in the constraints. No constraints => you have access only to Equals(object)
, GetHashCode()
, GetType()
, (and if you have the constraint class
: operator==
, operator!=
.) Of these two are virtual (Equals(object)
, GetHashCode()
), so you'll use the "correct" version, the third isn't normally overwritten (GetType()
), so you'll probably use the "correct" version. Only the two operators ==
/!=
are often overwritten and lo and behold! In your generic method you can't use the "correct" version of the two! :-)
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…