如果我重写Equals和GetHashCode,我该如何决定要比较哪些字段?如果我有两个对象,每个对应两个字段会发生什么,但Equals只检查一个字段?
换句话说,假设我有这个类:
class EqualsTestClass { public string MyDescription { get; set; } public int MyId { get; set; } public override bool Equals(object obj) { EqualsTestClass eq = obj as EqualsTestClass; if(eq == null) { return false; } else { return MyId.Equals(eq.MyId); } } public override int GetHashCode() { int hashcode = 23; return (hashcode * 17) + MyId.GetHashCode(); } }
如果它们具有相同的MyId,我认为两个对象相等.因此,如果Id相等但描述不同,它们仍然被认为是相等的.
我只是想知道这种方法的缺陷是什么?当然,像这样的结构将按预期运行:
List<EqualsTestClass> test = new List<EqualsTestClass>(); EqualsTestClass eq1 = new EqualsTestClass(); eq1.MyId = 1; eq1.MyDescription = "Des1"; EqualsTestClass eq2 = new EqualsTestClass(); eq2.MyId = 1; eq2.MyDescription = "Des2"; test.Add(eq1); if (!test.Contains(eq2)) { // Will not be executed,as test.Contains is true test.Add(eq2); }
由于eq2的值等于eq1,因此不会添加.但这是我控制的代码,但我想知道框架中是否存在可能导致意外问题的代码?
那么,我应该总是在我的Equals()比较中添加所有公共字段,或者是什么原则可以避免令人讨厌的惊喜,因为一些完全出乎意料的糟糕的Framework-Mojo?
解决方法
重写Equals()的原因是你定义了两个实例相等的含义.在某些情况下,这意味着所有字段必须相等,但它不必.你决定.
有关更多信息,请参阅documentation和post.