1.目的:
1. 1使用hashcode方法提前校验,可以避免每一次对比都使用equals方法,提高效率
1.2 保证是同一个对象,如果重写了equals方法,没有重写hashcode方法,那么会出现equals相等,hashcode不相等的情况,所以就是为了避免这种情况发生。
2.总结
hashCode主要用于提升查询效率,来确定在散列结构中对象的存储地址;
重写equals()必须重写hashCode(),二者参与计算的自身属性字段应该相同;
hash类型的存储结构,添加元素重复性校验的标准就是先取hashCode值,后判断equals();
equals()相等的两个对象,hashcode()一定相等;
反过来:hashcode()不等,一定能推出equals()也不等;
hashcode()相等,equals()可能相等,也可能不等
本文详细阐述了hashCode与equals方法在Java中的作用与实现原理。hashCode主要用于提升查询效率,确定对象在散列结构中的存储位置。当重写equals方法时,为保持一致性也必须重写hashCode方法。hash类型的存储结构会先通过hashCode值进行重复性校验,再调用equals方法进一步确认。equals相等的对象,hashCode必定相等;反之,hashCode不等则equals必定不等。
80

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



