一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務(wù)器之家 - 編程語(yǔ)言 - JAVA教程 - 詳解Java中Vector和ArrayList的區(qū)別

詳解Java中Vector和ArrayList的區(qū)別

2020-06-26 15:49川哥哥 JAVA教程

這篇文章主要為大家詳細(xì)介紹了Java中Vector和ArrayList的區(qū)別,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

首先看這兩類都實(shí)現(xiàn)List接口,而List接口一共有三個(gè)實(shí)現(xiàn)類,分別是ArrayListVector和LinkedList。List用于存放多個(gè)元素,能夠維護(hù)元素的次序,并且允許元素的重復(fù)。

3個(gè)具體實(shí)現(xiàn)類的相關(guān)區(qū)別如下:

1.ArrayList是最常用的List實(shí)現(xiàn)類,內(nèi)部是通過(guò)數(shù)組實(shí)現(xiàn)的,它允許對(duì)元素進(jìn)行快速隨機(jī)訪問(wèn)。數(shù)組的缺點(diǎn)是每個(gè)元素之間不能有間隔,當(dāng)數(shù)組大小不滿足時(shí)需要增加存儲(chǔ)能力,就要講已經(jīng)有數(shù)組的數(shù)據(jù)復(fù)制到新的存儲(chǔ)空間中。當(dāng)從ArrayList的中間位置插入或者刪除元素時(shí),需要對(duì)數(shù)組進(jìn)行復(fù)制、移動(dòng)、代價(jià)比較高。因此,它適合隨機(jī)查找和遍歷,不適合插入和刪除。

2.Vector與ArrayList一樣,也是通過(guò)數(shù)組實(shí)現(xiàn)的,不同的是它支持線程的同步,即某一時(shí)刻只有一個(gè)線程能夠?qū)慥ector,避免多線程同時(shí)寫(xiě)而引起的不一致性,但實(shí)現(xiàn)同步需要很高的花費(fèi),因此,訪問(wèn)它比訪問(wèn)ArrayList慢。

3.LinkedList是用鏈表結(jié)構(gòu)存儲(chǔ)數(shù)據(jù)的,很適合數(shù)據(jù)的動(dòng)態(tài)插入和刪除,隨機(jī)訪問(wèn)和遍歷速度比較慢。另外,他還提供了List接口中沒(méi)有定義的方法,專門用于操作表頭和表尾元素,可以當(dāng)作堆棧、隊(duì)列和雙向隊(duì)列使用。

查看Java源代碼,發(fā)現(xiàn)當(dāng)數(shù)組的大小不夠的時(shí)候,需要重新建立數(shù)組,然后將元素拷貝到新的數(shù)組內(nèi),ArrayList和Vector的擴(kuò)展數(shù)組的大小不同。 

ArrayList中:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
public boolean add(E e) {
 ensureCapacity(size + 1); // 增加元素,判斷是否能夠容納。不能的話就要新建數(shù)組
 elementData[size++] = e;
 return true;
}
 public void ensureCapacity(int minCapacity) {
 modCount++;
 int oldCapacity = elementData.length;
 if (minCapacity > oldCapacity) {
  Object oldData[] = elementData; // 此行沒(méi)看出來(lái)用處,不知道開(kāi)發(fā)者出于什么考慮
  int newCapacity = (oldCapacity * 3)/2 + 1; // 增加新的數(shù)組的大小
  if (newCapacity < minCapacity)
  newCapacity = minCapacity;
   // minCapacity is usually close to size, so this is a win:
   elementData = Arrays.copyOf(elementData, newCapacity);
 
 }
 
}

Vector中:

?
1
2
3
4
5
6
7
8
9
10
11
12
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);
 }
}

關(guān)于ArrayList和Vector區(qū)別如下:

ArrayList在內(nèi)存不夠時(shí)默認(rèn)是擴(kuò)展50% + 1個(gè),Vector是默認(rèn)擴(kuò)展1倍。
Vector提供indexOf(obj, start)接口,ArrayList沒(méi)有。
Vector屬于線程安全級(jí)別的,但是大多數(shù)情況下不使用Vector,因?yàn)榫€程安全需要更大的系統(tǒng)開(kāi)銷。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲欧美综合人成野草 | 男女污网站 | 女教师系列三上悠亚在线观看 | 亚洲国产精品一区二区久久 | 午夜免费啪视频观看视频 | 特级淫片大乳女子高清视频 | 久久精品亚洲牛牛影视 | 无敌在线视频观看免费 | 波多野结衣黑人系列在线观看 | 久久国产乱子伦精品免费不卡 | 香蕉eeww99国产精品 | 欧美整片在线 | 19+韩国女主播激情vip视频在线 | 日韩高清一区二区三区不卡 | 欧美va在线 | 国产午夜永久福利视频在线观看 | 女人叉开腿让男人桶 | 欧美一区二区三区四区视频 | 大学生特黄特色大片免费播放 | 亚洲一卡2卡4卡5卡6卡残暴在线 | jizz中国jizz老师水多 | 亚洲人成综合在线播放 | 羞羞色男人的天堂伊人久久 | 久见久热 这里只有精品 | 国产欧美日韩在线不卡第一页 | 高清一级片 | 好大好硬好深好爽gif图 | 草草线在成年免费视频网站 | 国产色婷婷亚洲 | 成人观看免费观看视频 | 欧洲肥女大肥臀 | 精品一区二区三区五区六区七区 | 日本美女xx | 欧美男男gaysgays | 欧美性野久久久久久久久 | 亚洲高清视频在线 | 国产视频一区二 | 美女机机对机机的视频(免费) | 小小水蜜桃视频高清在线播放 | 男人的天堂视频在线 | 99视频免费 |