У меня есть класс 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);
}
}
Когда я добавляю список объектов этого класса в хэш-набор:
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);
Все нормально, а ha.count
- 2
, но:
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));
Теперь ha.count
есть 3
.
- Почему метод
HashSet
не соответствуетa
CompareTo
. - Есть ли
HashSet
лучший способ иметь список уникальных объектов?