Java中List、 Set 和 Map 的初始容量和加载因子是什么?

xiaoxiao2025-12-04  8

List、 Set 和 Map 的初始容量和加载因子

答:

List ArrayList 的初始容量是10,加载因子为0.5;扩容增量:原容量的 0.5倍+1;一次扩容后长度为16。 Vector 初始容量为10,加载因子1。扩容增量:原容量的1倍,一次扩容后的容量为20。

Set HashSet,初始容量为16,加载因子为0.75;扩容增量:原容量的1.6倍;如 HAshSet 的容量为16,一次扩容后容量为32

Map HashMap,初始容量16,加载因子0.75;扩容增量:原容量的1倍;如 HashMap 的容量为16,一次扩容后容量为 32

加载因子是什么?

加载因子是表示Hsah表中元素的填满的程度。

若:加载因子越大,填满的元素越多,好处是,空间利用率高了,但:冲突的机会加大了。反之,加载因子越小,填满的元素越少,好处是:冲突的机会减小了,但:空间浪费多了。

冲突的机会越大,则查找的成本越高.反之,查找的成本越小.因而,查找时间就越小。

因此,必须在 "冲突的机会"与"空间利用率"之间寻找一种平衡与折衷. 这种平衡与折衷本质上是数据结构中有名的**"时-空"矛盾**的平衡与折衷。

转载请注明原文地址: https://www.6miu.com/read-5040351.html

最新回复(0)