比较两个Java对象时, 我们需要覆盖equals和  hashCode。

  1. public class User{
  2. private String name;
  3. private int age;
  4. private String passport;
  5. //getters and setters, constructor
  6. }
 

在比较结果时:

  1. User user1 = new User("mkyong", 35, "111222333");
  2. User user2 = new User("mkyong", 35, "111222333");
  3. System.out.println(user1.equals(user2)); // false

下面我们将介绍几种常用方法:

 

1.经典方式

这种17和31散列码的想法来自经典的Java书籍——《Effective Java》第九条。下面我们来看看是如何实现的...
  1. public class User {
  2. private String name;
  3. private int age;
  4. private String passport;
  5. //getters and setters, constructor
  6. @Override
  7. public boolean equals(Object o) {
  8. if (o == this) return true;
  9. if (!(o instanceof User)) {
  10. return false;
  11. }
  12. User user = (User) o;
  13. return user.name.equals(name) &&
  14. user.age == age &&
  15. user.passport.equals(passport);
  16. }
  17. //Idea from effective Java : Item 9
  18. @Override
  19. public int hashCode() {
  20. int result = 17;
  21. result = 31 * result + name.hashCode();
  22. result = 31 * result + age;
  23. result = 31 * result + passport.hashCode();
  24. return result;
  25. }
  26. }

2.JDK 7

对于JDK7及更新版本,你可以是使用java.util.Objects 来重写 equals 和 hashCode 方法,代码如下
 
  1. import java.util.Objects;
  2. public class User {
  3. private String name;
  4. private int age;
  5. private String passport;
  6. //getters and setters, constructor
  7. @Override
  8. public boolean equals(Object o) {
  9. if (o == this) return true;
  10. if (!(o instanceof User)) {
  11. return false;
  12. }
  13. User user = (User) o;
  14. return age == user.age &&
  15. Objects.equals(name, user.name) &&
  16. Objects.equals(passport, user.passport);
  17. }
  18. @Override
  19. public int hashCode() {
  20. return Objects.hash(name, age, passport);
  21. }
  22. }

3.Apache Commons Lang

或者,您可以使用Apache Commons LangEqualsBuilder 和HashCodeBuilder 方法。代码如下

  1. import org.apache.commons.lang3.builder;
  2. public class User {
  3. private String name;
  4. private int age;
  5. private String passport;
  6. //getters and setters, constructor
  7. @Override
  8. public boolean equals(Object o) {
  9. if (o == this) return true;
  10. if (!(o instanceof User)) {
  11. return false;
  12. }
  13. User user = (User) o;
  14. return new EqualsBuilder()
  15. .append(age, user.age)
  16. .append(name, user.name)
  17. .append(passport, user.passport)
  18. .isEquals();
  19. }
  20. @Override
  21. public int hashCode() {
  22. return new HashCodeBuilder(17, 37)
  23. .append(name)
  24. .append(age)
  25. .append(passport)
  26. .toHashCode();
  27. }
  28. }

最后测试总结:

在使用上述三种任何一种方式都可以到如下结果:
  1. User user1 = new User("mkyong", 35, "111222333");
  2. User user2 = new User("mkyong", 35, "111222333");
  3. System.out.println(user1.equals(user2)); // true</span>

其实后两种都是对于17和31散列码思想的封装实现。具体请参考《Effective Java》第九条。

如何正确的重写equals() 和 hashCode()方法的更多相关文章

  1. Java中==、equals、hashcode的区别与重写equals以及hashcode方法实例(转)

    Java中==.equals.hashcode的区别与重写equals以及hashcode方法实例  原文地址:http://www.cnblogs.com/luankun0214/p/4421770 ...

  2. 为什么要重写equals和hashcode方法

    equals hashcode  当新建一个java类时,需要重写equals和hashcode方法,大家都知道!但是,为什么要重写呢? 需要保证对象调用equals方法为true时,hashcode ...

  3. 【转】Java中==、equals、hashcode的区别与重写equals以及hashcode方法实例

    原文地址:http://www.cnblogs.com/luankun0214/p/4421770.html 感谢网友的分享,记录下来只为学习. 1.重写equals方法实例   部分代码参考http ...

  4. Java中==、equals、hashcode的区别与重写equals以及hashcode方法实例

    1.重写equals方法实例   部分代码参考http://blog.csdn.net/wangloveall/article/details/7899948 重写equals方法的目的是判断两个对象 ...

  5. java重写equals和hashCode方法

    一.重写equals方法 如果不重写equals,那么比较的将是对象的引用是否指向同一块内存地址,重写之后目的是为了比较两个对象的value值是否相等. 利用equals比较八大包装对象(如int,f ...

  6. 内存泄漏避雷!你真的了解重写equals()和hashcode()方法的原因吗?

    基本概念 要比较两个对象是否相等时需要调用对象的equals() 方法: 判断对象引用所指向的对象地址是否相等 对象地址相等时, 那么对象相关的数据也相等,包括: 对象句柄 对象头 对象实例数据 对象 ...

  7. 重写equals()与hashCode()方法

    出自:http://blog.csdn.net/renfufei/article/details/16339351 Java语言是完全面向对象的,在java中,所有的对象都是继承于Object类.Oj ...

  8. 重写equals() 和 hashCode()方法

    什么情况下需要重写呢? 比如去重操作时, 有时候往Set集合存放对象User,我们User类的字段太多时,比如有50个字段, 判断两个User对象相同,不需要判断它们所有字段都相同,只需要判断它们的某 ...

  9. List集合去重的一些方法(常规遍历、Set去重、java8 stream去重、重写equals和hashCode方法)

    1. 常规元素去重 碰到List去重的问题,除了遍历去重,我们常常想到利用Set集合不允许重复元素的特点,通过List和Set互转,来去掉重复元素. // 遍历后判断赋给另一个list集合,保持原来顺 ...

随机推荐

  1. 【物联网智能网关-17】.NET Micro Framework之MDK C++二次开发

    .NET Micro Framework虽然好学易用,但是在一些需要实时,需要高性能的应用领域,却有些勉为其难.毕竟.NET Micro Framework上层应用程序由底层CLR(TinyCLR)解 ...

  2. appfuse的使用方法

     2008-07-27  appfuse是如何使用的? 比如我想编写一个 struts+spring+hibernate+ajax的网站,如何用appfuse加速我的开发进度呢 ----------- ...

  3. git difftool 详解

    一.如何比较两个版本之间的差异 1.显示版本得到版本的commit id 2.执行difftool命令 按Y进行比较,我用的是DiffMerge这个软件对代码进行比较的 二.比较当前所修改的内容 gi ...

  4. UCP规模估算方法介绍 基于UCP方法的软件项目成本估计及其应用方法,软件,项目,UCP方法,应用,项目估算及软件及应用,软件估算,项目成本,软件项目

    基于UCP方法的软件项目成本估计及其应用 UCP说明: UCP = 交易的UCP数 + Actor的UCP数,1.交易/Actor在估算时按复杂度分为简单.普通.复杂.主观类别,权重分别对应1.2.3 ...

  5. STC单片机串口输出ADXL335角度值

    STC单片机串口输出ADXL335角度值: //***************************************************** //名称:单片机串口输出ADXL335角度值 ...

  6. MongoDB资料汇总专题

    原文地址:http://bbs.chinaunix.net/thread-3675396-1-1.html 上一篇Redis资料汇总专题很受大家欢迎,这里将MongoDB的系列资料也进行了简单整理.希 ...

  7. sql的行转列(PIVOT)与列转行(UNPIVOT) webapi 跨域问题 Dapper 链式查询 扩展 T4 代码生成 Demo (抽奖程序)

    sql的行转列(PIVOT)与列转行(UNPIVOT)   在做数据统计的时候,行转列,列转行是经常碰到的问题.case when方式太麻烦了,而且可扩展性不强,可以使用 PIVOT,UNPIVOT比 ...

  8. 【colaboratory】在colab中安装mxnet

    在学习<动手学深度学习>内容是,该内容用的是mxnet框架,在电脑本地安装过程中又容易出现错误,怎么也安装不上,所有的条件都尝试了. 汗颜,指的另谋他法. 只有在谷歌的学习平台上安装使用h ...

  9. C/C++/动态链接库DLL中函数的调用约定与名称修饰

    参见:http://blog.twofei.com/cc/impl/calling-convension.html 调用约定(Calling Convention)是指在程序设计语言中为了实现函数调用 ...

  10. Android面试之HashMap的实现原理

    1.HashMap与HashTable的区别 HashMap允许key和value为null: HashMap是非同步的,线程不安全,也可以通过Collections.synchronizedMap( ...