c# – 覆盖Equals()但不检查所有字段 – 会发生什么?

前端之家收集整理的这篇文章主要介绍了c# – 覆盖Equals()但不检查所有字段 – 会发生什么?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
如果我重写Equals和GetHashCode,我该如何决定要比较哪些字段?如果我有两个对象,每个对应两个字段会发生什么,但Equals只检查一个字段?

换句话说,假设我有这个类:

  1. class EqualsTestClass
  2. {
  3. public string MyDescription { get; set; }
  4. public int MyId { get; set; }
  5.  
  6. public override bool Equals(object obj)
  7. {
  8. EqualsTestClass eq = obj as EqualsTestClass;
  9. if(eq == null) {
  10. return false;
  11. } else {
  12. return MyId.Equals(eq.MyId);
  13. }
  14. }
  15.  
  16. public override int GetHashCode()
  17. {
  18. int hashcode = 23;
  19. return (hashcode * 17) + MyId.GetHashCode();
  20. }
  21. }

如果它们具有相同的MyId,我认为两个对象相等.因此,如果Id相等但描述不同,它们仍然被认为是相等的.

我只是想知道这种方法的缺陷是什么?当然,像这样的结构将按预期运行:

  1. List<EqualsTestClass> test = new List<EqualsTestClass>();
  2.  
  3. EqualsTestClass eq1 = new EqualsTestClass();
  4. eq1.MyId = 1;
  5. eq1.MyDescription = "Des1";
  6.  
  7. EqualsTestClass eq2 = new EqualsTestClass();
  8. eq2.MyId = 1;
  9. eq2.MyDescription = "Des2";
  10.  
  11. test.Add(eq1);
  12. if (!test.Contains(eq2))
  13. {
  14. // Will not be executed,as test.Contains is true
  15. test.Add(eq2);
  16. }

由于eq2的值等于eq1,因此不会添加.但这是我控制的代码,但我想知道框架中是否存在可能导致意外问题的代码

那么,我应该总是在我的Equals()比较中添加所有公共字段,或者是什么原则可以避免令人讨厌的惊喜,因为一些完全出乎意料的糟糕的Framework-Mojo?

解决方法

重写Equals()的原因是你定义了两个实例相等的含义.在某些情况下,这意味着所有字段必须相等,但它不必.你决定.

有关更多信息,请参阅documentationpost.

猜你在找的C#相关文章