博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JDK 是如何判断两个对象是否相同的?判断的流程是什么?
阅读量:6641 次
发布时间:2019-06-25

本文共 2344 字,大约阅读时间需要 7 分钟。

JDK 是如何判断两个对象是否相同的呢?判断的流程是什么?

参考解答:

JDK 会先判断两个对象的hashCode是否相同,如果hashCode不同,则说明肯定是两个不同的对象了;如果hashCode相同再通过equals()方法进行进一步比较,如果equals方法返回true,则说明两个对象是相同的,如果equals方法返回false说明两个对象不同。

如何验证

怎么来验证这个问题呢?我们知道HashSet是不允许存储相同的键值的。所以我们可以用HashSet存储两个相同的键值来模拟,看JDK是如何做判断和识别的,从而验证我们的猜想。

// 先自定义一个类并复写 hashCode 和 equals 方法public class CustomClass {    @Override    public int hashCode() {        System.out.println("判断 hashCode");        return 1; // 返回1,说明所有新建的对象的哈希值都为1,也就是相同    }    @Override    public boolean equals(Object o) {        System.out.println("判断 equals");        return true; // 返回true    }}

接下来我们用HashSet来存储两个自定义的CustomClass的对象,代码如下:

public class HashSetTest {    public static void main(String[] args) {              HashSet
hs = new HashSet<>(); CustomClass cs1 = new CustomClass(); CustomClass cs2 = new CustomClass(); hs.add(cs1); hs.add(cs2); System.out.println("----hs添加完毕"); System.out.println("hs:"+hs); // 打印一下hashSet集合看里面存放了什么 }}

打印结果如下:

判断 hashCode 判断 hashCode判断 equals----hs添加完毕判断 hashCode // 此处的判断是打印输出语句执行时调用的,与分析本问题无关hs:[com.alankeene.javalib.collections.CustomClass@1]

结果分析:

执行 hs.add(cs1) 语句的时候,JDK 会先判断 cs1 所指向对象的hashCode,因为是第一次往HashSet集合里面存放元素,该元素 hashCode 在集合中肯定是还没存在的,这是个新的元素,所以直接存放进集合中,不用调用 cs1 所指向对象的 equals 方法。
当执行 hs.add(cs2) 语句时,这是第二次往集合里存放元素,有新的元素 cs2 要添加进来,那先要调用 cs2 所指向对象的 hashCode 方法看看它的哈希值是不是与集合中已有元素的哈希值重复了,发现重复了,哈希值都是1,那有可能是同一个对象,那就要调用 cs2 所指向对象的 equals 方法做进一步判断,发现 equals 方法返回 true,则判断为是重复的元素,就不往集合里添加了。

所以最终打印 HashSet 集合的时候可以看到,集合中只存放了一个元素。

注:所以平时我们在自定义一个类时,要谨慎把 equals 方法的返回值静态的设置为 true,因为一旦产生哈希冲突,JDK 就会认为相同哈希值的对象就是同一个对象了。

我们再反证一下,把 equals 方法改为返回 false,模拟两个hashCode相同,但是是两个不同的对象的情景。

public class CustomClass {    @Override    public int hashCode() {        System.out.println("判断 hashCode");        return 1; // 返回1,说明所有新建的对象的哈希值都为1,也就是相同    }    @Override    public boolean equals(Object o) {        System.out.println("判断 equals");        return false; // 返回false    }}

打印结果会如下:

判断 hashCode 判断 hashCode判断 equals----hs添加完毕判断 hashCode // 此处的判断是打印输出语句执行时调用的,与分析本问题无关判断 hashCode // 此处的判断是打印输出语句执行时调用的,与分析本问题无关hs:[com.alankeene.javalib.collections.CustomClass@1, com.alankeene.javalib.collections.CustomClass@1]

会发现,HashSet集合中存放了两个元素了,说明虽然 cs1 和 cs2 的哈希值相同,但是 JDK 判断为不同的元素并存入集合中了。

由此,验证了我们的猜想。JDK 是先判断 hashCode,如果 hashCode 相同再通过 equals 去判断两个对象是否相同的。

转载地址:http://ptovo.baihongyu.com/

你可能感兴趣的文章
【震惊】百度推广网站被植入广告?这是善意还是恶意的?
查看>>
当存储无可用空间时无法启动虚拟机
查看>>
extern “C”总结
查看>>
获取用户id
查看>>
silverlight:telerik RadControls中RadGridView的一个Bug及解决办法
查看>>
ProgressForm
查看>>
管理之困:居高不下的流动率
查看>>
WPF之ComboBox的VisualTreeHelper
查看>>
spring开发_Spring+Hibernate_HibernateDaoSupport
查看>>
svn 客户端批量备份数据(图+文)
查看>>
GraphicsMagick的安装以及使用
查看>>
SQL中IN,NOT IN,EXISTS,NOT EXISTS的用法和差别
查看>>
find中的mtime,工作中遇(一直在改变系列5)
查看>>
Silverlight实用窍门系列:73.Silverlight的DataGrid分组以及模拟合并单元格
查看>>
快速哈希算法破坏了加密的安全性
查看>>
JS 实现网站简繁体切换
查看>>
HDU 1041 Computer Transformation(高精度)
查看>>
Exadata中最有用的功能-存储索引
查看>>
SGU 206 Roads
查看>>
Guide to Data Mining 读书笔记 相似度距离算法的取舍
查看>>