hashCode() 和 equals() 较量

要面试了,突击一下;

当比较两个对象是否相同时,需要重新该类的equals方法(自定义比较规则)。

那为啥要hashCode和equals方便放在一起来说话呢?

其实hashCode的出现,也是比较对象的一种手段。

因为某些情况下需要配合hashCode()来辅助比较两个对象是否相同(为了高效)。比如hash系的容器,hashSet,要保证元素唯一性,会先进行hashCode比较,如果hashCode不同说明时不同对象,如果hashCode相同,再比较equals是否相同,这样一来,hashCode的出现会大大减少equals方法的比较,达到更加高效的比较对象是否相同的目的。

这里就先不涉及hashCode如何实现了。

这里也记录一下大佬们的一些结论性语句,方便自己理解:
 1.hashCode是为了提高在散列结构存储中查找的效率,在线性表中没有作用。
 2.equals和hashCode需要同时覆盖(一定程度上为了保证hash容器的正常使用)。
 3.若两个对象equals返回true,则hashCode有必要也返回相同的int数。
 4.若两个对象equals返回false,则hashCode不一定返回不同的int数,但为不相等的对象生成不同hashCode值可以提高哈希表的性能。
 5.若两个对象hashCode返回相同int数,则equals不一定返回true。
 6.若两个对象hashCode返回不同int数,则equals一定返回false。
 7.同一对象在执行期间若已经存储在集合中,则不能修改影响hashCode值的相关信息,否则会导致内存泄露问题。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值