JavaDoc определяет набор как:
Коллекция, которая не содержит повторяющихся элементов.Более формально, наборы не содержат пары элементов e1 и e2, так что e1.equals (e2)
Чтобы проверить это, я создал очень простую программу:
import java.util.HashSet;
public class CheckHashSet {
public static void main(String[] args) {
HashSet<Employee> set = new HashSet<Employee>();
set.add(new Employee(10));
set.add(new Employee(10));
System.out.println(set.size());
System.out.println(new Employee(10).equals(new Employee(10)));
}
private static class Employee implements Comparable<Employee> {
private final int id;
public Employee(int id) {
this.id = id;
}
@Override
public int compareTo(Employee o) {
return this.id - o.id;
}
@Override
public boolean equals(Object obj) {
if(obj instanceof Employee) {
return compareTo((Employee)obj)==0;
}
return false;
}
}
}
Вывод программы:
2
true
Это означает, что new Employee(10).equals(new Employee(10))
возвращает true, тогда как set.add(new Employee(10)); set.add(new Employee(10));
добавляет объект дважды.
Что не так с моим кодом?