Этот вопрос и ответ Джона заставили меня осознать, что это вообще существует, поэтому я заинтересовался и запустил Visual Studio.
Я последовал одному примеру на странице MSDN, а затем создал свой собственный маленький пример. Это выглядит следующим образом:
public class Person : IEquatable<Person>
{
public string IdNumber { get; set; }
public string Name { get; set; }
public bool Equals(Person otherPerson)
{
if (IdNumber == otherPerson.IdNumber)
return true;
else
return false;
}
public override bool Equals(object obj)
{
if (obj == null)
return base.Equals(obj);
if (!(obj is Person))
throw new InvalidCastException("The Object isn't of Type Person.");
else
return Equals(obj as Person);
}
public override int GetHashCode()
{
return IdNumber.GetHashCode();
}
public static bool operator ==(Person person1, Person person2)
{
return person1.Equals(person2);
}
public static bool operator !=(Person person1, Person person2)
{
return (!person1.Equals(person2));
}
}
Итак, у меня есть пара вопросов:
Если метод Equals хорошо справляется с обработкой моего пользовательского равенства, почему я должен также переопределить метод GetHashCode?
При сравнении чего-либо подобного ниже, какой компаратор используется, равно или GetHashCode?
.
static void Main(string[] args)
{
Person sergio = new Person() { IdNumber = "1", Name = "Sergio" };
Person lucille = new Person() { IdNumber = "2", Name = "Lucille" };
List<Person> people = new List<Person>(){
sergio,
lucille
};
Person lucille2 = new Person() { IdNumber = "2", Name = "Lucille" };
if (people.Contains(lucille2))
{
Console.WriteLine("Already exists.");
}
Console.ReadKey();
}
- Что именно делает операторный метод? Похоже, там происходит какая-то черная магия вуду.