Which of the following is correct/better, considering that identity property could be null.
public override int GetHashCode()
{
if (ID == null) {
return base.GetHashCode();
}
return ID.GetHashCode();
}
OR
public override int GetHashCode()
{
if (ID != null) {
return ID.GetHashCode();
}
return 0;
}
Update 1: Updated 2nd option.
Update 2: Below are the Equals implementations:
public bool Equals(IContract other)
{
if (other == null)
return false;
if (this.ID.Equals(other.ID)) {
return true;
}
return false;
}
public override bool Equals(object obj)
{
if (obj == null)
return base.Equals(obj);
if (!obj is IContract) {
throw new InvalidCastException("The 'obj' argument is not an IContract object.");
} else {
return Equals((IContract)obj);
}
}
And ID is of string
type.
IEqualityComparer<T>
that will then be used to instantiate e.g. a dictionary by callingDictionary<TKey, TValue>(IEqualityComparer<TKey>)
– Marco