gpt4 book ai didi

java HashMap扩容详解及实例代码

转载 作者:qq735679552 更新时间:2022-09-29 22:32:09 25 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章java HashMap扩容详解及实例代码由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

HashMap扩容 。

前言:

HashMap的size大于等于(容量*加载因子)的时候,会触发扩容的操作,这个是个代价不小的操作.

为什么要扩容呢?HashMap默认的容量是16,随着元素不断添加到HashMap里,出现hash冲突的机率就更高,那每个桶对应的链表就会更长.

这样会影响查询的性能,因为每次都需要遍历链表,比较对象是否相等,一直到找到元素为止.

为了提升查询性能,只能扩容,减少hash冲突,让元素的key尽量均匀的分布.

扩容基本点 。

加载因子默认值是0.75 。

java" id="highlighter_774169">
?
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 。

最后此篇关于java HashMap扩容详解及实例代码的文章就讲到这里了,如果你想了解更多关于java HashMap扩容详解及实例代码的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com