Sollten wir beides außer Kraft setzen Equals
y GetHashCode
Eigenschaften bei der Implementierung eines benutzerdefinierten Klasseninstanzenvergleichs?
Im folgenden Code habe ich eine Sammlung von Klassen. Die Klasse A
wird mit dem ID
die Klasse B
- durch Code
.
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
namespace ConsoleApplication2
{
class Program
{
static void Main(string[] args)
{
List<I> bars = new List<I>();
bars.Add(new A() { Id = 1, Code = "one A" });
bars.Add(new B() { Id = 1, Code = "one B" });
bars.Add(new A() { Id = 1, Code = "one A+" });
bars.Add(new B() { Id = 1, Code = "one B" }); // Code = "one B+"
var distictBars = bars.Distinct();
foreach (var item in distictBars)
{
Debug.WriteLine(item.Code);
}
}
}
interface I
{
string Code { get; set; }
}
class A : I, IEquatable<A>
{
public int Id { get; set; }
public string Code { get; set; }
public bool Equals(A other)
{
// this is the ??? comparison
return this.Id == other.Id;
//return this.Code == other.Code;
}
public override bool Equals(object obj)
{
if (obj is A)
return this.Equals(obj as A);
else
return object.ReferenceEquals(this, obj);
}
public override int GetHashCode()
{
// this is the wanted comparison
return this.Id;
}
}
class B : I, IEquatable<B>
{
public int Id { get; set; }
public string Code { get; set; }
public bool Equals(B other)
{
// this is the ??? comparison
return this.Id == other.Id;
}
public override bool Equals(object obj)
{
if (obj is B)
return this.Equals(obj as B);
else
return object.ReferenceEquals(this, obj);
}
public override int GetHashCode()
{
// this is the wanted comparison
return this.Code.GetHashCode();
}
}
}
Die Ausgabe ist:
one A
one B
für den Fall, dass die kommentierte Code = "one B+"
die Ausgabe ist
one A
one B
one B+
Nun frage ich mich, wozu ich die Equals
en el B
Klasse, wenn es scheint, dass dies keine Auswirkungen auf den Vergleich hat?
Ist GetHasCode()
die für diese Art von Vergleichen ausreichen?