Ho una classe che è IComparable
:
public class a : IComparable
{
public int Id { get; set; }
public string Name { get; set; }
public a(int id)
{
this.Id = id;
}
public int CompareTo(object obj)
{
return this.Id.CompareTo(((a)obj).Id);
}
}
Quando aggiungo un elenco di oggetti di questa classe a un set di hash:
a a1 = new a(1);
a a2 = new a(2);
HashSet<a> ha = new HashSet<a>();
ha.add(a1);
ha.add(a2);
ha.add(a1);
Va tutto bene ed ha.count
è 2
, ma:
a a1 = new a(1);
a a2 = new a(2);
HashSet<a> ha = new HashSet<a>();
ha.add(a1);
ha.add(a2);
ha.add(new a(1));
Adesso lo ha.count
è 3
.
- Perché non
HashSet
rispettaa
ilCompareTo
metodo. - È
HashSet
il modo migliore per avere un elenco di oggetti unici?
IEqualityComparer<T>
nel costruttore o implementala nella classea
. msdn.microsoft.com/en-us/library/bb301504(v=vs.110).aspx