麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > Java > 正文

Java中Vector與ArrayList的區別詳解

2019-11-26 16:04:08
字體:
來源:轉載
供稿:網友
首先看這兩類都實現List接口,而List接口一共有三個實現類,分別是ArrayList、Vector和LinkedList。List用于存放多個元素,能夠維護元素的次序,并且允許元素的重復。
3個具體實現類的相關區別如下:

1.ArrayList是最常用的List實現類,內部是通過數組實現的,它允許對元素進行快速隨機訪問。數組的缺點是每個元素之間不能有間隔,當數組大小不滿足時需要增加存儲能力,就要講已經有數組的數據復制到新的存儲空間中。當從ArrayList的中間位置插入或者刪除元素時,需要對數組進行復制、移動、代價比較高。因此,它適合隨機查找和遍歷,不適合插入和刪除。

2.Vector與ArrayList一樣,也是通過數組實現的,不同的是它支持線程的同步,即某一時刻只有一個線程能夠寫Vector,避免多線程同時寫而引起的不一致性,但實現同步需要很高的花費,因此,訪問它比訪問ArrayList慢。

3.LinkedList是用鏈表結構存儲數據的,很適合數據的動態插入和刪除,隨機訪問和遍歷速度比較慢。另外,他還提供了List接口中沒有定義的方法,專門用于操作表頭和表尾元素,可以當作堆棧、隊列和雙向隊列使用。

查看Java源代碼,發現當數組的大小不夠的時候,需要重新建立數組,然后將元素拷貝到新的數組內,ArrayList和Vector的擴展數組的大小不同。
ArrayList中:
復制代碼 代碼如下:

public boolean add(E e) {
     ensureCapacity(size + 1);  // 增加元素,判斷是否能夠容納。不能的話就要新建數組
     elementData[size++] = e;
     return true;
 }
  public void ensureCapacity(int minCapacity) {
     modCount++;
     int oldCapacity = elementData.length;
     if (minCapacity > oldCapacity) {
         Object oldData[] = elementData; // 此行沒看出來用處,不知道開發者出于什么考慮
         int newCapacity = (oldCapacity * 3)/2 + 1; // 增加新的數組的大小
         if (newCapacity < minCapacity)
        newCapacity = minCapacity;
             // minCapacity is usually close to size, so this is a win:
             elementData = Arrays.copyOf(elementData, newCapacity);
     }
 }

Vector中:
復制代碼 代碼如下:

private void ensureCapacityHelper(int minCapacity) {
     int oldCapacity = elementData.length;
     if (minCapacity > oldCapacity) {
         Object[] oldData = elementData;
         int newCapacity = (capacityIncrement > 0) ?
        (oldCapacity + capacityIncrement) : (oldCapacity * 2);
         if (newCapacity < minCapacity) {
        newCapacity = minCapacity;
         }
        elementData = Arrays.copyOf(elementData, newCapacity);
     }
 }

關于ArrayList和Vector區別如下:
1.ArrayList在內存不夠時默認是擴展50% + 1個,Vector是默認擴展1倍。
2.Vector提供indexOf(obj, start)接口,ArrayList沒有。
3.Vector屬于線程安全級別的,但是大多數情況下不使用Vector,因為線程安全需要更大的系統開銷。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: aaaaaaa毛片 | 精品亚洲一区二区三区 | 欧美成人高清视频 | 亚洲欧美aⅴ | 色屁屁xxxxⅹ在线视频 | 一区在线视频 | 中国毛片在线观看 | 欧美日韩中文字幕在线视频 | 免费看性xxx高清视频自由 | 国产亚洲精品久久777777 | 免费毛片在线 | www国产成人免费观看视频,深夜成人网 | 亚洲人成综合第一网 | 婷婷久久青草热一区二区 | 一区在线看| 日韩精品中文字幕一区二区三区 | 成人免费午夜视频 | 国产成人精品免高潮在线观看 | 在线看毛片的网站 | 在线观看视频毛片 | 日本一区二区在线看 | 懂色av懂色aⅴ精彩av | www.guochan| 性爱视频在线免费 | 黄色大片www | 国产亚洲精品久久久闺蜜 | caoporn国产一区二区 | 国产免费观看av | 成人黄色小视频网站 | 久久精品久| 成人福利视频在线观看 | 91在线视频精品 | 久久精品一区二区三区国产主播 | 精品久久久久久国产三级 | 91网站永久免费看 | 中文字幕一区在线观看视频 | 亚洲成年人免费网站 | 色中色在线播放 | 神秘电影91 | 黄色大片在线免费看 | 香蕉视频99|