equals与hashCode

1、关于Object的这两个方法

在这里插入图片描述
在这里插入图片描述

总结:

  1. Object时所有类的父类,默认的equals()方法时对地址进行比较,而hashCode()方法的时根据地址进行计算
  2. equals()方法比较结果相等,那么hashCode()方法计算的结果也必须相等;
  3. equals()方法比较结果不相等,那么hashCode()方法计算的结果也未必不等;
  4. 在一个应用期内,在equals()比较中,如果信息未发生该百年,那么多次调用hashCode(),值必定相等,但多个应用期内,无要求;

2、为什么重写equals,一定要重写hashCode?

如果equals、hashCode都不重写;则两个方法都源自Object

同一对象,地址必然相等,equals肯定相等,对应的hashCode也必然相等;
不同对象,地址必然不等,equals肯定不等,对应的hashCode则可能相等;

如果equals重写、hashCode不重写;则hashCode源自Object

同一对象,地址必然相等,equals相等,对应的hashCode必然相等;
不同对象,地址必然不等,equals可能相等,也可能不等,对应的hashCode也可能相等,也可能不等;这违背上面总结的第二点:

equals()方法比较结果相等,那么hashCode()方法计算的结果也必须相等;

以HashMap为例,根据hashCode进行元素的获取,即使是两个相等的key(key重写equals,未要重写hashCode),则可能计算出不一样的hashCode,hashCode不相等,肯定获取不到对应的value。

3、equals重写方法建议

  1. 显式参数命名为otherObject,稍后需要将它转换成另一个叫做other的变量(参数名命名,强制转换请参考建议5)
  2. 检测this与otherObject是否引用同一个对象 :if(this == otherObject) return true;(存储地址相同,肯定是同个对象,直接返回true)
  3. 检测otherObject是否为null ,如果为null,返回false.if(otherObject == null) return false;
  4. 比较this与otherObject是否属于同一个类 (视需求而选择)

    如果equals的语义在每个子类中有所改变,就使用getClass检测if(getClass()!=otherObject.getClass()) return false; (参考前面分析的第6点)
    如果所有的子类都拥有统一的语义,就使用instanceof检测 :if(!(otherObject instanceof ClassName)) return false;

  5. 将otherObject转换为相应类的类型变量:ClassName other = (ClassName) otherObject;
  6. 现在开始对所有需要比较的域进行比较 。使用==比较基本类型域,使用equals比较对象域。如果所有的域都匹配,就返回true,否则就返回flase。

    如果在子类中重新定义equals,就要在其中包含调用super.equals(other)
    当此方法被重写时,通常有必要重写 hashCode 方法,以维护 hashCode 方法的常规协定,该协定声明 相等对象必须具有相等的哈希码 。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值