java8 hashmap扩容机制
默认情况下HashMap的容量是16,如果用户通过构造函数指定了一个数字作为容量,那么Hash会选择大于该数字的第一个2的幂作为容量。(3->4、7->8、9->16)
如果map在put的时候发现超过阙值的时候就会产生扩容:
阙值 = 负载因子 * 容量
threshold = loadFactor * capacity
所以我们知道map里存放的个数时候,new的构造函数的设置值应该利用公式 = (需要存储的个数 / 负载因子)+ 1
比如map里要存放16个元素
(16 / 0.75) + 1 = 22
1 2 3 4 5 6 7 8 9 10 11 | Map<String, String> map = new HashMap<String, String>( 22 ); // int n = cap - 1; // n |= n >>> 1; // n |= n >>> 2; // n |= n >>> 4; // n |= n >>> 8; // n |= n >>> 16; // return (n < 0) ? 1 : (n >= MAXIMUM_CAPACITY) ? MAXIMUM_CAPACITY : n + 1; map容量变成 32 阙值 = 32 * 0.75 = 24 此时我们存放 16 个元素就不会触发扩容 |
不积跬步,无以至千里;不积小流,无以成江海
分类:
学习的整理
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!