HashMap扩容
前言:
HashMap的size大于等于(容量*加载因子)的时候,会触发扩容的操作,这个是个代价不小的操作。
为什么要扩容呢?HashMap默认的容量是16,随着元素不断添加到HashMap里,出现hash冲突的机率就更高,那每个桶对应的链表就会更长,
这样会影响查询的性能,因为每次都需要遍历链表,比较对象是否相等,一直到找到元素为止。
为了提升查询性能,只能扩容,减少hash冲突,让元素的key尽量均匀的分布。
扩容基本点
加载因子默认值是0.75
?
|
1
|
static final float DEFAULT_LOAD_FACTOR = 0.75f;
|
容量的默认值是16
?
|
1
|
static final int DEFAULT_INITIAL_CAPACITY = 1 << 4; // 等于16
|
HashMap提供了一个构造参数,可以在创建的时候指定容量和加载因子。
?
|
1
|
public HashMap(int initialCapacity, float loadFactor)
|
默认的情况下,HashMap 的size一旦大于等于16*0.75=12的话,
同时每个Entry(或者叫桶)里面至少有一个元素的时候就会进行扩容。
?
|
1
2
3
4
5
|
if ((size >= threshold) && (null != table[bucketIndex])) {
resize(2 * table.length);
hash = (null != key) ? hash(key) : 0;
bucketIndex = indexFor(hash, table.length);
}
|
扩容的时候,容器容量翻倍
?
|
1
|
resize(2 * table.length);
|
扩容的时候需要重新计算元素的数组下标
1、重新分配一个新的Entry数组
2、重新计算原来元素的在新数组中的下标(比较耗资源)
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
原文链接:http://blog.csdn.net/linsongbin1/article/details/54695986
相关文章
猜你喜欢
- 64M VPS建站:能否支持高流量网站运行? 2025-06-10
- 64M VPS建站:怎样选择合适的域名和SSL证书? 2025-06-10
- 64M VPS建站:怎样优化以提高网站加载速度? 2025-06-10
- 64M VPS建站:是否适合初学者操作和管理? 2025-06-10
- ASP.NET自助建站系统中的用户注册和登录功能定制方法 2025-06-10
TA的动态
- 2025-07-10 怎样使用阿里云的安全工具进行服务器漏洞扫描和修复?
- 2025-07-10 怎样使用命令行工具优化Linux云服务器的Ping性能?
- 2025-07-10 怎样使用Xshell连接华为云服务器,实现高效远程管理?
- 2025-07-10 怎样利用云服务器D盘搭建稳定、高效的网站托管环境?
- 2025-07-10 怎样使用阿里云的安全组功能来增强服务器防火墙的安全性?
快网idc优惠网
QQ交流群
您的支持,是我们最大的动力!
热门文章
-
JoshChen_web格式编码UTF8-无BOM的小细节分析
2025-05-29 92 -
2025-05-27 26
-
2025-05-25 18
-
spring boot使用i18n时properties文件中文乱码问题的解决方法
2025-05-27 90 -
2025-05-27 89
热门评论

