假设我们有如下的一个类:
class MyObject {
private String id1;
private String id2;
@Override
public boolean equals(Object o) {
if (o == this) return true;
if (!(o instanceof MyObject)) {
return false;
}
MyObject other = (MyObject) o;
return id1.equals(other.id1) || id2.equals(other.id2);
}
}
请注意,相等性不取决于两个字段是否匹配,任何一个字段都可以。对于这个类,什么样的hashCode实现会更合适?
HashMap
转换为LinkedList
。 - Andreas