为什么重写了 equals 还要重写 hashCode
借鉴:https://blog.csdn.net/weixin_44061521/article/details/128194172
日期:2023年2月4日21:52:49
如有不足或不对的地方,欢迎指正错误。
先说结论:在 java 中,当往哈希(散列)集合中添加元素时,会先去判断 hashCode 值是否相同,如果不同,则直接插入。如果相同,才去用 equals 判断。
注意:
-
两个对象的 hashCode 值如果不同,则对象一定不同。
-
两个对象的 hashCode 值如果相同,则对象可能相同,也可能不同,需要用 equals 去比较。
先用 hashCode 去判断对象是否相同可以提升效率,避免直接用 euqals 判断节省了时间。
这也就是为什么用了 hashCode 之后还要用 equals 方法去判断。
下面展开说明一下:
1. 先说一下为什么要重写 equals 方法?
对于引用类型来说,如果不重写 equals 方法,即使调用 equals 方法,默认还是是通过 == 来比较两个对象的地址。
没有重写 equals 方法,Person 类会调用其父类 Object 的 equals 方法。
- Object 类的 equals 方法
public boolean equals(Object obj) {
return (this == obj);
}
但在实际业务中,我们都是通过 属性是否相等 来判断两个对象是否为同一个。
创建一个 Person 类用来测试,属性只有一个 name,方便测试:
- Person 类
public class Person {
private String name;
public Person() {
}
public Person(String name) {
this.name = name;
}
}
- 测试
public class MyTest {
public static void