日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

StringBuffer、StringBuilder、ArrayList、Vector、HashMap、HashTable 的扩容机制

發布時間:2025/4/16 编程问答 21 豆豆
生活随笔 收集整理的這篇文章主要介紹了 StringBuffer、StringBuilder、ArrayList、Vector、HashMap、HashTable 的扩容机制 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1. StringBuffer、StringBuilder 的擴容機制

StringBuffer、StringBuilder,默認初始化是 16 個字符,默認增容為 原長度+2
→ 擴容后:2*(n+1)

代碼如下:

//默認初始化大小 public StringBuilder() {super(16); }// 默認擴容 int newCapacity = (value.length + 1) * 2;

2. ArrayList 的擴容機制

ArrayList,初始默認長度為 10 ,每次擴容是 原容量的一半
→ 擴容后:1.5*n

具體代碼如下:

public ArrayList() {this(10); } int newCapacity = (oldCapacity * 3)/2 + 1;public static native void arraycopy(Object src, int srcPos, Object dest, int destPos, int length);

3. Vector 的擴容機制

Vector,初始默認長度為 10 ,每次擴容是 原容量的一倍
→ 擴容后:2*n

具體代碼如下:

public Vector() {this(10); } int newCapacity = (capacityIncrement > 0) ? (oldCapacity + capacityIncrement) : (oldCapacity * 2);

4. HashMap 的擴容機制

HashMap,初始默認長度為 16必須是2的次方),默認每次的擴容因子為 0.75
→ 擴容后:2*n

具體代碼如下:

static final int DEFAULT_INITIAL_CAPACITY = 16; static final float DEFAULT_LOAD_FACTOR = 0.75f;public HashMap() {this.loadFactor = DEFAULT_LOAD_FACTOR;threshold = (int)(DEFAULT_INITIAL_CAPACITY * DEFAULT_LOAD_FACTOR);table = new Entry[DEFAULT_INITIAL_CAPACITY];init(); }resize(2 * table.length);

5. HashTable 的擴容機制

HashTable,默認初始 11 ,默認每次擴容的因子為 0.75
→ 擴容后:2*n+1

具體代碼如下:

public Hashtable() {this(11, 0.75f); }int newCapacity = oldCapacity * 2 + 1;

總結

以上是生活随笔為你收集整理的StringBuffer、StringBuilder、ArrayList、Vector、HashMap、HashTable 的扩容机制的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。