1
0
mirror of https://github.com/Snailclimb/JavaGuide synced 2025-06-16 18:10:13 +08:00

update HashMap 链表转红黑树条件

This commit is contained in:
houzhenguo 2019-11-06 19:55:47 +08:00
parent 5345b5d608
commit 26efacb56e

View File

@ -18,7 +18,7 @@
## HashMap 简介 ## HashMap 简介
HashMap 主要用来存放键值对它基于哈希表的Map接口实现</font>是常用的Java集合之一。 HashMap 主要用来存放键值对它基于哈希表的Map接口实现</font>是常用的Java集合之一。
JDK1.8 之前 HashMap 由 数组+链表 组成的,数组是 HashMap 的主体,链表则是主要为了解决哈希冲突而存在的(“拉链法”解决冲突).JDK1.8 以后在解决哈希冲突时有了较大的变化,当链表长度大于阈值(默认为 8将链表转化为红黑树以减少搜索时间。 JDK1.8 之前 HashMap 由 数组+链表 组成的,数组是 HashMap 的主体,链表则是主要为了解决哈希冲突而存在的(“拉链法”解决冲突).JDK1.8 以后在解决哈希冲突时有了较大的变化,当链表长度大于阈值(默认为 8将链表转化为红黑树(将链表转换成红黑树前会判断,如果当前数组的长度小于 64那么会选择先进行数组扩容而不是转换为红黑树,以减少搜索时间,具体可以参考 `treeifyBin`方法
## 底层数据结构分析 ## 底层数据结构分析
### JDK1.8之前 ### JDK1.8之前