item 11: Always override hashCode when you override equals
- 重写了
equals方法时必须也要重写hashCode方法 - 需要满足一致性
- 如果两个对象的equals,调用hashCode也不许返回一样的值
- 如果两个对象不equals,不强调调用各自的hashcode方法时也必须不同——所以“极限”操作,hashCode总返回42
一般做法——:
- 定义一个result值;可以进行lazy初始化
- 计算关键属性的hash值:
- 返回result值
- 非关键属性可以忽略
需要思考性能影响;懒初始化;使用“奇质数”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 - 选择关键属性
- 生成对应的equals或hashCode方法
例如: return Objects.hashCode(pcId, emailAddress, reporterId, numberInfo, idNum);
© 版权声明
文章版权归作者所有,未经允许请勿转载。如内容涉嫌侵权,请在本页底部进入<联系我们>进行举报投诉!
THE END


















暂无评论内容