1.使用hashcode方法提前校验,可以避免每一次比对都调用equals方法,提高效率
2.保证是同一个对象,如果重写了equals方法,而没有重写hashcode方法,会出现equals相等的对象,hashcode不相等的情况,重写hashcode方法就是为了避免这种情况的出现。
hashCode()与 equals()的相关规定
如果两个对象相等,则 hashcode 一定也是相同的
两个对象相等,对两个对象分别调用 equals 方法都返回 true
两个对象有相同的 hashcode 值,它们也不一定是相等的
因此,equals 方法被覆盖过,则 hashCode 方法也必须被覆盖
hashCode() 的默认行为是对堆上的对象产生独特值。如果没有重写 hashCode(),则该 class 的两个对象无论如何都不会相等(即使这两个对象指向相同的数据)
总结:
就一句,规定,因为为了提高效率,hash类型的存储结构,添加元素重复性校验的标准就是先取hashCode值,后判断equals(),不重写达不到判等效果。

本文深入解析hashCode与equals方法的重要性及其实现原则。hashCode用于提高对象比较的效率,equals用于判断对象是否相等。若equals被重写,hashCode也必须重写以确保一致性。文章详细解释了hashCode与equals在hash类型存储结构中的作用。
1628

被折叠的 条评论
为什么被折叠?



