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 时,会触发数组的扩容机制。
相关推荐
凯瑟琳.奥古斯特9 小时前
常见加密算法及应用
java·开发语言·网络·网络协议·职场和发展
devilnumber9 小时前
java的lambda妙用举例
java·lambda
invicinble9 小时前
springboot提供的机制大全
java·spring boot·后端
Han_han9199 小时前
题⽬ 4:订单商品统计:
java
彦为君9 小时前
JavaSE-11-ByteBuffer(NIO核心组件)
java·开发语言·前端·数据库·后端·spring·nio
刀法如飞9 小时前
《理解道德经》简单版-第 1 章:道可道,非常道
前端·后端·面试
Kiling_07049 小时前
面向对象和集合编程题 ( 二 )
java·开发语言·数据结构·算法
菜鸡儿齐9 小时前
Future接口学习
java·服务器·开发语言