比较两个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. excel查找和替换

    快捷键:ctrl+f或者ctrl+h组合键 1.该功能经常会用到,但是需要注意的是“选项”功能,可以确定查找范围,区分大小写等. 2.如何控制查找范围? 1)设置范围--确定是查找工作表还是工作薄,同 ...

  2. linux-env命令解析

    Linux的env命令查看当前用户的环境信息 [root@linux ~]# envHOSTNAME=linux.dmtsai.tw   <== 这部主机的主机名称SHELL=/bin/bash ...

  3. SQLserver视图修改sql

    语法: alter view dbo.视图名 as 更新后的视图SQL go 举个栗子: 原视图名为YOUR_VIEW其中SQL为:  select * form TableA 更新视图: alter ...

  4. NYOJ----蛇形填数

    蛇形填数 时间限制:3000 ms  |  内存限制:65535 KB 难度:3   描述 在n*n方陈里填入1,2,...,n*n,要求填成蛇形.例如n=4时方陈为: 10 11 12 1 9 16 ...

  5. C语言学习笔记 (001) - 常量指针与指针常量的区别(转帖)

    三个名词虽然非常绕嘴,不过说的非常准确.用中国话的语义分析就可以很方便地把三个概念区分开. 一) 常量指针. 常量是形容词,指针是名词,以指针为中心的一个偏正结构短语.这样看,常量指针本质是指针,常量 ...

  6. HDU 4301 Divide Chocolate (DP + 递推)

    Divide Chocolate Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  7. 防盗链之URL参数签名 总结

    一.概述 传统的 IP 禁用.referer 防盗链.User-Agent 防盗链.地区访问控制等防盗链措施已经无法完全满足用户要求,所以开发出URL参数签名方式来防盗链 二.实现 Token防盗链是 ...

  8. 【SqlServer】SqlServer存储过程使用

    我们一开始学习数据库语言的时候就是用一些简单的insert,select等语法,但是随着我们学习数据库的深入,就会发现一些简单的语法满足不了我们的要求,比如处理一些业务逻辑,多表关联的时候,还有就是虽 ...

  9. MyBatis---使用MyBatis Generator生成Dto、Dao、Mapping

    由于MyBatis属于一种半自动的ORM框架,所以主要的工作将是书写Mapping映射文件,但是由于手写映射文件很容易出错,所以查资料发现有现成的工具可以自动生成底层模型类.Dao接口类甚至Mappi ...

  10. golang ----rune数据类型

    查询,官方的解释如下: // rune is an alias for int32 and is equivalent to int32 in all ways. It is // used, by ...