面试官:为什么重写equals方法必须要重新hashCode方法?

网络上解释的很全面但是很枯涩,也有些难懂,其实就是为了保证当该对象作为key时哈希表的检索效率。如HashMap的get方法是分两步获取的

  • 第一步通过key的哈希值找到对应的哈希桶
  • 第二步通过equals方法来判断是否为同一个key(因为可能出现哈希冲突)

假设一个Student类有三个属性:学号、姓名、年龄,但是只要学号相同我们就认为是同一个学生。这个时候我们重写equals方法

java 复制代码
public class Student {
    private String idCard;
    private String name;
    private String age;

    @Override
    public boolean equals(Object obj) {
        if (obj instanceof Student) {
            if (this.idCard.equals(((Student) obj).idCard)) {
                return true;
            }
        }
        return false;
    }
}

如果不重写hashCode方法,当从一个Map里通过Student对象作为key检索时,如果只有学号相同而姓名和年龄不同就会导致hashCode大概率不同,那get方法检索时第一步通过hashCode就找不到这个对象,所以就会get为null,但是我们认为学号相同就是同一个对象,我们是想找到这个对象的,这与我们的初衷相违背。

所以我们约定重写equals方法就必须重写hashCode方法,即"约定一致性"

java 复制代码
public class Student {
    private String idCard;
    private String name;
    private String age;

    @Override
    public boolean equals(Object obj) {
        if (obj instanceof Student) {
            if (this.idCard.equals(((Student) obj).idCard)) {
                return true;
            }
        }
        return false;
    }

    @Override
    public int hashCode() {
        return this.idCard.hashCode();
    }
}

这样get方法第一步就能通过相同的hashCode找到对象,然后再通过equals方法就能判断是同一个对象了

相关推荐
南山十一少3 小时前
Spring Security+JWT+Redis实现项目级前后端分离认证授权
java·spring·bootstrap
427724004 小时前
IDEA使用git不提示账号密码登录,而是输入token问题解决
java·git·intellij-idea
chengooooooo5 小时前
苍穹外卖day8 地址上传 用户下单 订单支付
java·服务器·数据库
李长渊哦5 小时前
常用的 JVM 参数:配置与优化指南
java·jvm
计算机小白一个5 小时前
蓝桥杯 Java B 组之设计 LRU 缓存
java·算法·蓝桥杯
南宫生7 小时前
力扣每日一题【算法学习day.132】
java·学习·算法·leetcode
计算机毕设定制辅导-无忧学长8 小时前
Maven 基础环境搭建与配置(一)
java·maven
风与沙的较量丶9 小时前
Java中的局部变量和成员变量在内存中的位置
java·开发语言
m0_748251729 小时前
SpringBoot3 升级介绍
java
极客先躯10 小时前
说说高级java每日一道面试题-2025年2月13日-数据库篇-请说说 MySQL 数据库的锁 ?
java·数据库·mysql·数据库的锁·模式分·粒度分·属性分