Java中重写equals一定要重写hashCode吗?

本文深入探讨了在Java中重写equals方法时为何必须同时重写hashCode方法。解释了equals用于判断对象相等性,而hashCode用于确定对象在哈希表中的位置,强调了在自定义类作为散列数据结构键时,二者一致性的必要性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  

  重写 equals,同时需要重写 hashCode,原因要从 equals 和 hashCode 方法的作用说起。

  equals 的作用:判断两个对象是否相等。

  hashCode 的作用:获取对象的哈希码,也称散列码,就是一个 int 整数。

  而哈希码的作用是确定对象在哈希表中的索引位置。

  当我们创建对象的散列表时,如HashMap、HashTable、HashSet,要保证相同的对象,哈希码一定相同(反之则不一定)。

  不然的话,假如通过equals判断对象是相等的,但是通过hashCode获取两个对象的哈希码却是不相同的,

  那么就会出现在散列表不同的索引位置上存储着相同的对象,这在HashSet中更是不允许的,因为Set集合中是不应该出现重复数据的。

  

  equals 方法默认实现是使用“==”比较两个对象是否相等,也就是判断对象的存储地址来判断对象是否相等;

  hashCode 方法默认情况下也是根据对象的存储地址进行映射来获取哈希码;

  也就是说在不重写equals和hashCode的情况下,他们默认的实现机制可以保证相同的对象,哈希码一定是相同的。

 

  因此,如果重写了equals,但是没有重写hashCode,那么就不能保证相同的对象哈希码一样。

  当自己创建的类的对象要作为 使用散列的数据结构(如HashMap等)的键时,必须要同时重写equals和hashCode方法。

 

  参考:《Java编程思想》

       https://www.cnblogs.com/skywang12345/p/3324958.html

       https://www.cnblogs.com/dolphin0520/p/3681042.html

     

 

转载于:https://www.cnblogs.com/starinbrook/p/9361543.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值