已解决
HashMap 的底层数据结构是什么?
来自网友在路上 167867提问 提问时间:2023-10-25 10:16:15阅读次数: 67
最佳答案 问答题库678位专家为你答疑解惑
HashMap 的底层数据结构是什么?
在JDK1.7 中,由“数组+链表”组成:数组是 HashMap 的主体,链表则是主要为了解决哈希冲突而存在的。
在JDK1.8 中,由“数组+链表+红黑树”组成:当链表过长,则会严重影响 HashMap 的性能,红黑树搜索时间复杂度是 O(logn),而链表是糟糕的 O(n)。因此,JDK1.8 对数据结构做了进一步的优化,引入了红黑树,链表和红黑树在达到一定条件会进行转换:
● 当链表长度 > 8 && 数组长度 >= 64 才会转红黑树; 其实这种情况,发生的概率很低。
● 将链表转换成红黑树前会判断,如果当前数组的长度小于 64,那么会选择先进行数组扩容,而不是转换为红黑树,以减少搜索时间。因为,数组扩容在一定程度上也可以减少哈希冲突如的发生。
查看全文
99%的人还看了
相似问题
猜你感兴趣
版权申明
本文"HashMap 的底层数据结构是什么?":http://eshow365.cn/6-24116-0.html 内容来自互联网,请自行判断内容的正确性。如有侵权请联系我们,立即删除!
- 上一篇: 数据可视化的常见工具
- 下一篇: Springboot + screw 数据库快速开发文档