
0关注
552
文章
0
收藏
2
次赞
281266
查看
Ta的博客 更多
SpringBoot 五种获取ApplicationContext的方式java中进行日期时间比较的4种方法SpringBoot整合WebSocket实现前后端互推消息CSS怎么画五角星?SpringBoot中RedisUtils工具类配置及直接使用HashMap 的扩容机制是怎样的?
解析
一般情况下,当元素数量超过阈值时便会触发扩容。每次扩容的容量都是之前容量的 2 倍。 HashMap 的容量是有上限的,必须小于1073741824。如果容量超出了这个 数,则不再增长,且阈值会被设置为 Integer.MAX\_VALUE。 JDK7 中的扩容机制
⚫ 空参数的构造函数:以默认容量、默认负载因子、默认阈值初始化数组。内部数组是空数组。
⚫ 有参构造函数:根据参数确定容量、负载因子、阈值等。
⚫ 第一次 put 时会初始化数组,其容量变为不小于指定容量的 2 的幂数,然后根据负载因子确定阈值。
⚫ 如果不是第一次扩容,则 新容量=旧容量 x 2 ,新阈值=新容量 x 负载因子 。 JDK8 的扩容机制
⚫ 空参数的构造函数:实例化的 HashMap 默认内部数组是 null,即没有实例化。第一次调用 put 方法时,则会开始第一次初始化扩容,长度为 16。
⚫ 有参构造函数:用于指定容量。会根据指定的正整数找到不小于指定容量的 2 的幂数,将这个数设置赋值给阈值(threshold)。第一次调用 put 方法时,会将阈值赋值给容量,然后让 阈值 = 容量 x 负载因子。
⚫ 如果不是第一次扩容,则容量变为原来的 2 倍,阈值也变为原来的 2 倍。(容量和阈值都变为原来的 2 倍时,负载因子还是不变)。 此外还有几个细节需要注意:
⚫ 首次 put 时,先会触发扩容(算是初始化),然后存入数据,然后判断是否需要扩容;
⚫ 不是首次 put,则不再初始化,直接存入数据,然后判断是否需要扩容;
0 0