Java 面试常见问题之——为什么重写equals时必须重写hashCode方法
当重写 equals 方法时,通常也应该重写 hashCode 方法,原因主要有以下几点:
- 一致性原则:根据 Java 的约定,如果两个对象通过 equals 方法比较返回 true,那么它们的 hashCode值也必须相等。如果重写了 equals 方法但没有重写 hashCode 方法,就可能会违反这个原则,导致在使用基于哈希的数据结构(如 HashSet、HashMap 等)时出现不可预测的错误。
- 哈希集合和哈希映射的正确行为:这些数据结构依赖于对象的 hashCode 方法来快速定位和存储元素。如果两个相等的对象具有不同的 hashCode,那么在这些集合中可能会被当作不同的元素处理,这与预期的行为不符。
- 提高性能:正确重写 hashCode 方法可以提高在哈希数据结构中的查找和存储效率。
hashCode() 的作用是获取哈希码,也称为散列码;它实际上是返回一个int整数。
这个哈希码的作用是确定该对象在哈希表中的索引位置。
如果两个对象相等,则hashcode一定也是相同的如果两个对象相等,对两个对象分别调用equals方法都返回true如果两个对象有相同的hashcode 值,它们也不一定是相等的因此,equals方法被覆盖过,则hashCode方法也必须被覆盖。
hashCode()的默认行为是对堆上的对象产生独特值。
如果没有重写hashCode(),则该class的两个对象无论如何都不会相等(即使这两个对象指向相同的数据).
总之,重写 equals 方法时重写 hashCode 方法可以保证对象在哈希相关的数据结构中的行为符合预期,保持一致性,并提高性能。