Java中重写equals()时都要重写hashCode()?

equals()方法和hashCode()方法都是Java中Object父类定义的方法

equals()在Object类中是比较两对象的地址是否相同,比如String字符串重写equals方法变成比较两字符串的值是否相等

String类重写的equals():

public boolean equals(Object anObject) {
    if (this == anObject) {
        return true;
    }
    if (anObject instanceof String) {
        String anotherString = (String)anObject;
        int n = value.length;
        if (n == anotherString.value.length) {
            char v1[] = value;
            char v2[] = anotherString.value;
            int i = 0;
            while (n-- != 0) {
                if (v1[i] != v2[i])
                    return false;
                i++;
            }
            return true;
        }
    }
    return false;
}

例如我们在使用HashSet集合时的保存步骤:

  1. 首先会通过hashCode()获取对象的哈希值,找到对应的哈希桶
  2. 若此时桶里没有数据则代表当前集合中无重复数据
  3. 若此时桶里有数据,则通过equals()方法判断两对象是否相等
  4. 若相等则代表hashSet中已有相同的数据,则该数据无法存入
  5. 若不相等则形成哈希链表(哈希碰撞)

在这个过程中,若每个数据都进行equals()比较的话,对于大量数据下将会带来巨大的比较成本,大大增加代码的时间复杂度,而引入hashCode则减少了equals()比较次数

所以

如果重写hashCode()不重写equals()?

则对象在哈希值相同的情况下equals()比较地址不同则导致误判

而如果重写equals()而不重写hashCode()?

则直接在比较哈希值时就会产生错误

所以,在重写equals()必须要重写hashCode()

  • 7
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值