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个元素就不会触发扩容

 

 

posted on   胡子就不刮  阅读(1160)  评论(0编辑  收藏  举报

编辑推荐:
· 开发者必知的日志记录最佳实践
· 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 让容器管理更轻松!

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示