0

0

如何在Java中正确重写 equals 和 hashCode_对象比较的设计要点

P粉602998670

P粉602998670

发布时间:2025-12-17 08:20:54

|

180人浏览过

|

来源于php中文网

原创

正确重写equals和hashCode需遵守自反性、对称性、传递性、一致性和非空性;先判断引用是否相同,再通过instanceof检查类型并比较关键字段;若重写equals则必须重写hashCode,确保相等对象具有相同哈希码,通常用31乘以各关键字段哈希值累加,以提升哈希表性能。

如何在java中正确重写 equals 和 hashcode_对象比较的设计要点

在Java中正确重写 equalshashCode 方法是对象比较和集合操作的基础。如果处理不当,可能导致逻辑错误,尤其是在使用 HashMap、HashSet 等基于哈希的集合时。

equals 方法的设计要点

默认情况下,Object 类的 equals 方法比较的是对象的内存地址(即 == 比较)。当我们需要根据对象的实际内容判断相等性时,就必须重写该方法。

重写 equals 方法需遵守以下约定(来自 Object 类规范):

  • 自反性:x.equals(x) 必须返回 true
  • 对称性:若 x.equals(y) 为 true,则 y.equals(x) 也必须为 true
  • 传递性:若 x.equals(y) 且 y.equals(z) 都为 true,则 x.equals(z) 也应为 true
  • 一致性:只要对象未被修改,多次调用 equals 应返回相同结果
  • 非空性:x.equals(null) 必须返回 false

实际编写时建议遵循以下步骤:

立即学习Java免费学习笔记(深入)”;

  • 先判断是否是同一引用(this == obj)
  • 使用 instanceof 判断传入对象是否为 null 或类型不匹配
  • 将对象强转为当前类型
  • 逐字段比较关键属性(如 ID、姓名、时间戳等)
// 示例:Person 类的 equals 实现
public class Person {
    private String id;
    private String name;
<pre class='brush:java;toolbar:false;'>@Override
public boolean equals(Object obj) {
    if (this == obj) return true;
    if (obj == null || getClass() != obj.getClass()) return false;
    Person person = (Person) obj;
    return id.equals(person.id) && name.equals(person.name);
}

}

hashCode 方法的设计要点

根据 Java 规范,如果两个对象通过 equals 判断相等,那么它们的 hashCode 必须相同。反之则不一定成立(即哈希码相同不代表对象相等)。

因此,只要重写了 equals,就必须重写 hashCode,否则会破坏哈希集合的行为。

设计原则:

Rytr写作助手
Rytr写作助手

Rytr 是一款AI内容生成和写作助手,可帮助您在短短几秒钟内以极低的成本创建高质量的内容!

下载
  • 在程序执行期间,只要对象用于 equals 比较的关键字段不变,hashCode 就应保持一致
  • equals 返回 true 的两个对象,hashCode 必须相等
  • 尽量让不同对象产生不同的哈希值以提升性能(减少冲突)

常见实现方式是组合关键字段的哈希值:

// 示例:Person 类的 hashCode 实现
@Override
public int hashCode() {
    int result = id.hashCode();
    result = 31 * result + name.hashCode();
    return result;
}

数字 31 是一个奇素数,编译器可优化为位运算(31 * i == (i

使用 IDE 或 Lombok 简化实现

手动编写 equals 和 hashCode 容易出错,尤其是字段较多时。推荐使用工具辅助生成:

  • IDEA / Eclipse:可通过右键 Generate → equals() and hashCode() 自动生成
  • Lombok:添加 @EqualsAndHashCode 注解即可自动处理
// 使用 Lombok 的简洁写法
@EqualsAndHashCode
public class Person {
    private String id;
    private String name;
}

注意:Lombok 默认包含所有非静态字段。如需排除某些字段,可用 @EqualsAndHashCode(exclude = {"name"})。

不可变对象更安全

如果对象的状态在创建后不再改变(即不可变对象),那么其 equals 和 hashCode 更加稳定,适合做 Map 的 key 或 Set 的元素。

建议:

  • 将参与比较的字段设为 final
  • 在构造函数中初始化
  • 避免提供 setter 方法修改关键字段

这样可以防止对象放入 HashSet 后因字段变化导致无法查找的问题。

基本上就这些。只要记住:重写 equals 一定要重写 hashCode,字段决定相等性,哈希影响性能,工具能帮你少犯错。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

255

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

1153

2024.03.01

c++ 字符处理
c++ 字符处理

本专题整合了c++字符处理教程、字符串处理函数相关内容,阅读专题下面的文章了解更多详细内容。

0

2026.03.17

minimax视频生成教程汇总
minimax视频生成教程汇总

本专题整合了minimax生成视频相关教程,阅读下面的文章了解更多详细操作。

0

2026.03.17

c++ 读取二进制文件
c++ 读取二进制文件

本专题整合了c++读取二进制文件相关内容与教程,阅读专题下面的文章了解更多详细操作。

0

2026.03.17

c++ 全局变量
c++ 全局变量

本专题整合了c++全局变量的使用、定义、作用域等等内容,阅读专题下面的文章了解更多详细内容。

0

2026.03.17

c++ 全局变量
c++ 全局变量

本专题整合了c++全局变量的使用、定义、作用域等等内容,阅读专题下面的文章了解更多详细内容。

0

2026.03.17

Nginx跨平台安装实操指南:Windows、macOS与Linux环境快速搭建
Nginx跨平台安装实操指南:Windows、macOS与Linux环境快速搭建

本指南详解Nginx在Windows、macOS及Linux系统的安装全流程。涵盖官方包解压、Homebrew一键部署、APT/YUM源配置及Docker容器化方案。无论新手或开发者,均可快速搭建运行环境,掌握跨平台核心指令,为后续配置与调优奠定坚实基础。

11

2026.03.16

chatgpt使用指南
chatgpt使用指南

本专题整合了chatgpt使用教程、新手使用说明等等相关内容,阅读专题下面的文章了解更多详细内容。

22

2026.03.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 4.5万人学习

C# 教程
C# 教程

共94课时 | 11.5万人学习

Java 教程
Java 教程

共578课时 | 83.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号