概述
HashMap是基于哈希表的Map接口实现的一种存储key、value的数据结构,提供了所有可选的映射操作,且键值允许null的存在,不保证数据映射的顺序,也不能保证顺序在一段时间内保持不变
底层结构
jdk1.7:数组+链表

jdk1.8:数组+链表+红黑树

哈希冲突
从上文图中显而易见,hashMap用的拉链法来解决哈希冲突的,也就是当一个数据计算出来的hash值已经在table数组中存在的话,就以链表的结构追加在后面
- 当链表长度>=8且数组长度>=64时,会把链表转化为红黑树
- 当链表长度>=8,当数组长度<64时,会优先进行扩容,而不是转化为红黑树
- 当红黑树节点数<=6时,自动转化为链表

最低0.47元/天 解锁文章
3万+

被折叠的 条评论
为什么被折叠?



