浅谈java中HashMap键的比较方式
作者:东风吹雨
先看一个例子
Integer integer=12344; Integer integer1=12344;
在Java中Integer 和Integer1是不相等的,但是如果再执行如下语句
map.put(integer, 1); map.put(integer1, 2);
会发现2会把1覆盖,问题来了,明明是两个不同的对象,为什么,2会把1覆盖呢?
我们看HashMap中添加键的源代码,如下
可以发现我们传进来的键交给了一个hash的成员方法区处理,这里我们看看hash方法的源码
哦,看到这里明白了,我们传进来的键会执行hashCode方法,那么到这里我们明白了,原来,HashMap判断两个键是否相等是看他们的hashCode
是否相等,
那我们看看上面说的integer和integer1的hashCode是否相等
这里发现是相等的,都是12344,所以我们可以很轻易的得出结论integer和integer1代表的是同一个键~,(这个结论是错的,继续往下看)
到这里还有一个问题,hashCode相等的两个对象他们的键一定是相同的吗?
先说答案不是,为什么呢?
来,我再举一个例子,先定义两个字符串name,name1
然后输出他们的hashCode值
可以看出,这两个不同的字符串拥有相同的hashCode值,
那么我们执行如下代码
看看他的输出结果
嗯?怎么会这样?我们定义的两个字符串明明hashCode值相同,按理来说,他们在HashMap中应该是同一个键才对,为什么会是两个不同的键?
我们再回过头看HashMap中的put方法
发现他调用了一个叫putVal得方法我们点进去看看
看到这里我们明白了,为什么name和name1hashCode值相同却是两个不同的键,因为他们进行equals比较的时候不同呀,name是"通话",name1是"重地",equals方法不同,自然就是同的键,
至于我们一开始举的例子,integer和integer1,他们先进行了hashCode比较,相同后再进行,equals比较,再相同才判定他们是同一个键;
这也是我们为什么常常说,为什么重写equals还要重写hashcode,这两者缺一不可
到此这篇关于浅谈java中HashMap键的比较方式的文章就介绍到这了,更多相关java HashMap键内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
您可能感兴趣的文章:
- Java LinkedHashMap 底层实现原理分析
- 浅谈Java源码ConcurrentHashMap
- Java ConcurrentHashMap的使用示例
- Java7和Java8中的ConcurrentHashMap原理解析
- Java源码解析之HashMap的put、resize方法详解
- JAVA核心知识之ConcurrentHashMap源码分析
- 详解 Java HashMap 实现原理
- java使用HashMap实现斗地主(有序版)
- 解决Java Redis删除HashMap中的key踩到的坑
- Java中使用HashMap改进查找性能的步骤
- Java中HashMap里面key为null存放到哪
- Java HashSet(散列集),HashMap(散列映射)的简单介绍
- java中JSONObject转换为HashMap(方法+main方法调用实例)
- Java 对HashMap进行排序的三种常见方法
- Java HashMap源码及并发环境常见问题解决
- 关于Java HashMap自动排序的简单剖析
- Java HashMap实现原理分析(一)
- JAVA中哈希表HashMap的深入学习