为什么重写 equals 方法必须重写 hashcode 方法
equals 方法和 hashCode 都是 Object 中定义的方法,它们经常被一起重写。
equals 方法是用来比较对象大小是否相等的方法,hashcode 方法是用来判断每个对象 hash 值的方法。
如果只重写 equals 方法而不重写 hashcode 方法,很可能会造成两个不同的对象,它们的 hashcode 也相等,造成冲突。
例如:
public static void main(String[] args) {
System.out.println("==========");
String a1 = "通话";
String a2 = "重地";
System.out.println(a1.hashCode() == a2.hashCode()); //true
System.out.println(a1.equals(a2)); // false
}
它们两个的 hashcode 值相等,但是 equals 不相等。
总结:
- 如果在 Java 运行期间对同一个对象调用 hashCode 方法后,无论调用多少次,都应该返回相同的 hashCode;但是在不同的 Java 程序中,执行 hashCode 方法的返回值可能不一致。
- 如果两个对象的 equals 相等,那么 hashCode 必须相同。
- 如果两个对象 equals 不相等,那么 hashCode 也有可能相同,所以需要重写 hashCode 方法,因为不知道 hashCode 的底层构造,所以需要重写 hashCode 方法,来为不同的对象生成不同的 hashCode 值,这样能够提高不同对象的访问速度。
- hashCode 通常是将地址转换为整数来实现的。
两个对象的 hashcode 相同,那么 equals 是否也一定为 true
不一定。例如,重写了 hashcode 方法,来算取余数,那么可能两个对象的 hashcode 会重复(即相等),但是两个对象的 equals 却不一定相同。
也就是说,就算是 hashcode 相同的字符串,equals 也有可能不同。