HashMap

HashMap1.7数组+链表

1.8 数组+链表/红黑树

hashmap存放值的时候,经过2次hash计算,得到桶下标的位置,放入数组的下标位置

为什么要这么做呢,不能够直接放入?

因为在获取的时候,直接放入,查找的时候,需要遍历数组,直到找到这个值才行

而2次hash,就可以获取到桶下标的位置,根据下标的位置获取数据

为什么要2次hash呢?1次hash不行吗?

减少hash冲突,重复的可能性,让数据尽可能的分布均匀一点,让链表的长度尽可能减少

桶下标的计算

二次hash值%数组长度 的余数

为了减少链表的长度,有哪些办法?

1.扩容

2.红黑树

hashmap元素在数组长度超过3/4的时候,就会扩容?

通下标就会根据现有的数组长度 进行2次hash,那么桶下标就会随之改变

树化阈值 >8

数组容量>=64

为什么要用红黑树,为何不一上来就树化,树化的阈值为什么是8,何时会树化,何时会退化成链表?

使用红黑树就是为了解决链表过长的问题

如果链表过短的话,查询效率未必比红黑树差,而且内存占用上比红黑树少

根据泊松分布,一个桶中元素为8个点概率0.000006

在扩容的时候,树会进行拆分,树的元素小于等于6,会退化成链表

在移除时,移除前 检查,root根节点,root左子节点,root右子节点,root左子节点的左子节点,如果不存在,则退化成链表

索引如何计算?hashcode有了,hash方法?数组的容量为什么是2的N次幂?

先拿到元素的hashcode,然后在调用hash方法,最后&(数组的长度-1),得到桶下标的位置

二次hash是为了让数据分布的更加均匀一点,减少hash冲突,那么某个下标的链表长度就会更少

在2的n次幂的情况下, 二次hash值取模数组长度 = 2次hash值 &(数组的长度-1)

hashmap put的流程?1.7 1.8的不同?

hashmap 一开始会是一个空集合,在添加元素的时候,会创建一个16大小的集合

拿到key的hashcode,2次hash,&(数组长度-1)

如果桶下标已经存在数据,形成链表

当数组的长度达到64,并且链表的长度为8的时候,这个元素的链表才会进行升级成红黑树

为啥负载因子是0.75?

大于这个值,空间节省了,但是链表的长度可能就会更高

小于这个值,查询性能高了,但是空间浪费了

hashmap的key可以为null,必须实现hashcode和equals方法,key的对象不可变

hashmap每次扩容的大小

  • 初始容量为 16(默认),第一次扩容后容量变为 32
  • 每次都是2倍
相关推荐
折哥的程序人生 · 物流技术专研9 小时前
Java面试85题图解版 · 特别篇:2026后端高频面试题复盘(算法底层逻辑+高并发架构设计全解析,附Java实战代码)
java·网络·数据库·算法·面试
一条泥憨鱼10 小时前
【Redis】数据类型和常用命令
java·数据库·redis·后端·缓存
云烟成雨TD10 小时前
Spring AI Alibaba 1.x 系列【78】沙箱(Sandbox)
java·人工智能·spring
程序员二叉10 小时前
【Java】 异常高频面试题精讲 | 易错点+对比总结
java·开发语言·面试
周航宇JoeZhou10 小时前
JB3-9-SpringAI(二)
java·ai·agent·多智能体·调度·智能体·观察
好家伙VCC10 小时前
Web Components主题热切换方案揭秘
java·前端
慕木沐11 小时前
Google ADK Java 1.0版本 核心机制与实战 Demo
java·开发语言·python
焦虑的说说12 小时前
秒杀系统设计方案
java
许彰午12 小时前
30_Java Stream流操作全解
java·windows·python
qq_25183645712 小时前
基于java Web网络订餐系统设计与实现 源码文档
java·开发语言·前端