item 11: Always override hashCode when you override equals
- 重寫了
equals方法時必須也要重寫hashCode方法 - 需要滿足一致性
- 如果兩個對象的equals,調(diào)用hashCode也不許返回相同的值
- 如果兩個對象不equals,不強調(diào)調(diào)用各自的hashcode方法時也必須不同——所以“極限”操作,hashCode總返回42
一般做法——:
- 定義一個result值;可以進行l(wèi)azy初始化
- 計算關(guān)鍵屬性的hash值:
- 返回result值
- 非關(guān)鍵屬性可以忽略
需要考慮性能影響;懶初始化;使用“奇質(zhì)數(shù)”odd prime
// hashCode method with lazily initialized cached hash code
private int hashCode; // Automatically initialized to 0
@Override public int hashCode() {
int result = hashCode;
if (result == 0) {
result = Short.hashCode(areaCode);
result = 31 * result + Short.hashCode(prefix);
result = 31 * result + Short.hashCode(lineNum);
hashCode = result;
}
return result;
}
可以利用IDE的自動處理功能:
- 選擇一個模板,例如 Guava’s
com.google.common.hash.Hashing - 選擇關(guān)鍵屬性
- 生成對應(yīng)的equals或hashCode方法
例如: return Objects.hashCode(pcId, emailAddress, reporterId, numberInfo, idNum);