为什么要去重写这两个方法
equals()
equals 使用的 == 去进行判断, 是基本数据类型的时候判断值是否相等, 当时引用数据类型的时候判断地址值是否相等
public boolean equals(Object obj) {
return (this == obj);
}
如果要比较对象属性值是否相等, 则要重写equals()
和hashCode()
Person p1 = new Person("迪丽热巴",18);
Person p2 = new Person("迪丽热巴",18);
System.out.println(p1.equals(p2)); //false
为什么重写equals的同时要重写hashCode, 先看一下代码
Person p1 = new Person("迪丽热巴",18);
Person p2 = new Person("迪丽热巴",18);
System.out.println("p1:"+p1);
System.out.println("p2:"+p2);
System.out.println("p1:"+p1.hashCode());
System.out.println("p2:"+p2.hashCode());
/*
p1:com.itheima.demo01.Object.Person@4554617c
p2:com.itheima.demo01.Object.Person@74a14482
p1:1163157884
p2:1956725890
*/
System.out.println(p1.equals(p2)); //true
System.out.println(p1.hashCode()==p2.hashCode()); //false
可以看到p1.equals(p1)返回了true, 但是两者的哈希值不相等
但是hashCode 中规定若equals相等则hashCode也应当相等
- 在 Java 应用程序执行期间,在对同一对象多次调用 hashCode 方法时,必须一致地返回相同的整数,前提是将对象进行 equals 比较时所用的信息没有被修改。从某一应用程序的一次执行到同一应用程序的另一次执行,该整数无需保持一致。
- 如果根据 equals(Object) 方法,两个对象是相等的,那么对这两个对象中的每个对象调用 hashCode 方法都必须生成相同的整数结果。
- 如果根据 equals(java.lang.Object) 方法,两个对象不相等,那么对这两个对象中的任一对象上调用 hashCode 方法不 要求一定生成不同的整数结果。但是,程序员应该意识到,为不相等的对象生成不同整数结果可以提高哈希表的性能。
同时因为HashSet或Map等集合中判断元素是否相等用到了hashCode是否相等,所以为避免我们认为相等但是逻辑判断却不相等的情况出现,自定义类重写equals必须重写hashCode方法
IDEA中快捷重写equals和hashCode
在IDEA中, 使用alt+insert
, 快捷重写这两个方法