回答重点
在Java中,hashCode()和equals方法的关系主要体现在集合类(如HashMap、HashSet)中。
他俩决定了对象的逻辑相等性和哈希存储方式
equals()方法:
- 用于判断两个对象是否相等,默认实现是使用==比较对象的内存地址,但可以在类中重写equals()来定义自己的相等逻辑
hashCode()方法:
- 返回对象的哈希值,主要用于基于哈希的集合(如HashMap、HashSet)。同一个对象每次调用hashCode()必须返回相同的值,且内容相等的对象必须有相同的哈希值
两者的关系
在Java 中,hashCode 方法和equals方法之间有一个“合约”:
- 如果两个对象根据equals方法被认为是相等的,那么它们必须具有相同的哈希码。
- 如果两个对象具有相同的哈希码,它们并不一定相等,但会被放在同一个哈希桶中。(哈希桶就是HashMap底层的数组)
注意:如果违背上述关系会导致在基于哈希的集合中出现错误行为。例如,HashMap可能无法正确存储和查找元素
扩展知识
为什么要重写hashCode()和equals()
因为在使用HashMap、HashSet等集合时,这些集合内部依赖hashCode()和equals{)方法来确定元素的存储位置。如果没有正确地重写这两个方法,集合可能无法正确判断对象的相等性,导致重复存储、查找失败等问题。
【Java基础面试题028】Java中的hashCode和equals方法,与==操作符有什么区别?-CSDN博客
重写equals()的基本规则
自反性:对于任何非空引用值×,x.equals(x)必须返回true。
对称性:对于任何非空引用值×和y,如果x.equals(y)返回true,则y.equals(x)也必须返回true。
传递性:对于任何非空引用值×、y 和z,如果x.equals(y)返回true 且y.equals(z)返回true,则x.equals(z)也必须返回true。
一致性:对于任何非空引l用值×和y,只要对象在比较中没有被修改,多次调用x.equals(y)应返回相同的结果。
对于任何非空引|用值×,x.equals(null)必须返回false。
重写hashCode()的基本规则
- 在相同的应用程序执行过程中,对于同一个对象多次调用hashCode()必须返回相同的值
- 如果两个对象根据equals()方法相等,则hashCode()值必须相等
- 但是如果两个equals()不相等,它们的hashCode()值不必相同,但不同的hashCode()值可以提高哈希表的性能