だから私は hashcode() と equals() メソッドについて質問があります
両方のメソッドをオーバーライドする非常に基本的なプログラムを書いたとしましょう
import java.util.*;
class Employee
{
private String name;
private int empid;
public Employee(String name,int empid)
{
this.name=name;
this.empid=empid;
}
public int getEmpid()
{
return empid;
}
public String getName()
{
return name;
}
public boolean equals(Object obj)
{
System.out.println("equals has just been called...");
Employee e1=(Employee)obj;
return ((name.equals(e1.name)) && (empid==e1.empid));
}
public int hashCode()
{
System.out.println("hashcode called...");
return empid;
}
}
次に、HashSet の要素を追加して反復する別のクラスを作成するとします。
class Five
{
public static void main(String args[])
{
HashSet hs1=new HashSet();
hs1.add(new Employee("Alex",25));
hs1.add(new Employee("Peter",25));
hs1.add(new Employee("Martin",25));
hs1.add(new Employee("Alex",25));
Iterator itr=hs1.iterator();
while(itr.hasNext())
{
Employee e=(Employee)itr.next();
System.out.println(e.getEmpid()+"\t"+e.getName());
}
}
}
今問題は、同じ empid で常に 3 回呼び出された equals() で Alex を再度追加しようとしたときです。
インデックス n ハッシュマップがないため、以前に追加された Alex で最初にチェックされた場合、true が返され、他の 2 つの要素 (ピーターとマーティン) に対して呼び出されるべきではありませんが、常に 3 回呼び出されます。
どうして..??
同じバケット内のオブジェクトにもインデックスがあります..??