HashMap 源码解析 底层原理 面试如何回答

HashMap 源码解析 底层原理 面试如何回答

一、参考资料

【Java视频教程,java入门神器(附300道Java面试题剖析)】 https://www.bilibili.com/video/BV1PY411e7J6/?p=172\&share_source=copy_web\&vd_source=855891859b2dc554eace9de3f28b4528

二、笔记总结

2.1、创建工程





2.2、HashMap 构造方法源码


2.3、HashMap put 方法源码

















2.4、面试如何回答

  • JDK 1.8 中 HashMap 中保存的是 Node 对象,key 和 value 都是 Node 对象的属性。
  • JDK 1.8 中 HashMap 底层数据结构是,数组+链表+红黑树。
    • 当数组某个索引位置上的元素个数达到 8 时并且数组长度达到 64 时,这个索引位置的存储结构由链表转为红黑树,可以提高查询、修改、删除操作的效率。
    • 当使用红黑树的索引位置上的元素数量低于 6 时,存储结构退化为链表结构,因为红黑树占用的空间大。
  • HashMap 在使用 put 方法添加元素时
    • 会根据要添加元素的 key 的 hashCode 方法计算 hash 值,然后根据 hash 值计算出元素在数组中的存储位置。
    • 当数组存储位置上已经存在元素时,如果两个元素的 key 计算出的 hash 值不相同,则说明是两个不同的元素,旧的元素的 next 属性会指向新的元素,形成链表结构,HashMap 中的元素都是 Node 对象,Node 对象有 next 属性,用于记录下一个元素的位置。
    • 如果两个元素的 key 计算出的 hash 值相同,equals 方法比较返回 true,说明是两个相同的 key,则把旧元素的 value 值替换为新元素的 value 值,put 方法会返回被替换的旧 value 值
    • 如果数组存储位置上没有元素,则直接添加元素到数组存储位置上,put 方法返回 null
  • HashMap 默认的数组大小是 16,计算因子默认是 0.75,16 * 0.75 = 12,当数组的长度达到临界值 12 时,会触发数组的扩容机制。
相关推荐
Purple Coder4 小时前
基于DGN的电工基础-8
职场和发展
无限的鲜花5 小时前
反射(原创推荐)
java·开发语言
IT二叔5 小时前
Java项目部署-03-teamcity-cicd-docker镜像流水线方式部署
java·ci/cd·持续部署
一路向北he5 小时前
字节钢铁军团--“提供情境,而非控制”
java·开发语言·前端
超级数据查看器6 小时前
超级数据查看器 v10.0 发布
java·大数据·数据库·sqlite·安卓
Waay6 小时前
面试口述版:个人对 Prometheus 完整理解
运维·学习·云原生·面试·职场和发展·kubernetes·prometheus
折哥的程序人生 · 物流技术专研7 小时前
《Java 100 天进阶之路》第50篇:阻塞队列与并发容器(2026版)
java·面试题·java进阶·blockingqueue·并发容器·集合源码·java100天进阶
ai_coder_ai7 小时前
编写自动化脚本,在自己后端服务中使用Open Api进行设备相关操作
java·运维·自动化
yuhaiqiang7 小时前
随手 vibecoding 的浏览器插件已经 6000 多次下载,聊聊他的产品设计
前端·后端·面试
硕风和炜8 小时前
【LeetCode: 2492. 两个城市间路径的最小分数 + DFS】
java·算法·leetcode·深度优先·dfs·bfs·并查集