次の 2 つのクラスがありFoo1
、HashMap
. Foo1
オブジェクトが等しい場合、2 つのオブジェクトは等しく、バイト配列が を満たす場合、オブジェクトは等しいFoo2
です。Foo2
Arrays.equals()
hashCode()
のメソッドに対して何をすべきかよくわかりませんFoo1
。各オブジェクトのハッシュコードを合計する必要があるだけFoo2
ですか、それとも非効率ですか?
public class Foo1 {
Foo2[] foo2_array;
@Override
public boolean equals(Object Other) {
for (int i = 0; i < foo2_array.length; i++) {
if (!foo2_array[i].equals(other.foo2_array[i])
return false;
}
return true;
}
@Override
public int hashCode() {
// what to here?
}
}
public class Foo2 {
byte[] values;
@Override
public boolean equals(Object other) {
return Arrays.equals(values, other.values);
}
@Override
public int hashCode() {
return Arrays.hashCode(values);
}
}