私はハッシュテーブルのputメソッドのJavaの実装を調べていて、これに出くわしました:
// Makes sure the key is not already in the hashtable.
Entry tab[] = table;
int hash = key.hashCode();
int index = (hash & 0x7FFFFFFF) % tab.length;
for (Entry<K,V> e = tab[index] ; e != null ; e = e.next) {
if ((e.hash == hash) && e.key.equals(key)) {
V old = e.value;
e.value = value;
return old;
}
}
衝突をチェックするにはキーが必要であることを理解していますが、なぜJavaはキーのハッシュ値を保存し、それもチェックするのですか?