Skip to content

Commit 2cfca91

Browse files
authored
修改 JDK1.8 之前的 HashMap 底层数据结构分析
1 parent d85b8fe commit 2cfca91

File tree

1 file changed

+1
-1
lines changed

1 file changed

+1
-1
lines changed

Java相关/HashMap.md

+1-1
Original file line numberDiff line numberDiff line change
@@ -22,7 +22,7 @@ JDK1.8 之前 HashMap 由 数组+链表 组成的,数组是 HashMap 的主体
2222

2323
## 底层数据结构分析
2424
### JDK1.8之前
25-
JDK1.8 之前 HashMap 底层是 **数组和链表** 结合在一起使用也就是 **链表散列****HashMap 通过 key 的 hashCode 经过扰动函数处理过后得到 hash 值,hash 值相同时,通过拉链法解决冲突**
25+
JDK1.8 之前 HashMap 底层是 **数组和链表** 结合在一起使用也就是 **链表散列****HashMap 通过 key 的 hashCode 经过扰动函数处理过后得到 hash 值,然后通过 `(n - 1) & hash` 判断当前元素存放的位置(这里的 n 指的时数组的长度),如果当前位置存在元素的话,就判断该元素与要存入的元素的 hash 值以及 key 是否相同,如果相同的话,直接覆盖,不相同就通过拉链法解决冲突**
2626

2727
**所谓扰动函数指的就是 HashMap 的 hash 方法。使用 hash 方法也就是扰动函数是为了防止一些实现比较差的 hashCode() 方法 换句话说使用扰动函数之后可以减少碰撞。**
2828

0 commit comments

Comments
 (0)