JavaVector和ArrayList的異同點(diǎn)是什么

這篇文章主要講解了“Java Vector和ArrayList的異同點(diǎn)是什么”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“Java Vector和ArrayList的異同點(diǎn)是什么”吧!

成都創(chuàng)新互聯(lián)公司專注于企業(yè)營銷型網(wǎng)站建設(shè)、網(wǎng)站重做改版、通道網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、HTML5建站成都商城網(wǎng)站開發(fā)、集團(tuán)公司官網(wǎng)建設(shè)、成都外貿(mào)網(wǎng)站建設(shè)、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為通道等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。

1.相同點(diǎn)

(1)都是有序集合。

(2)數(shù)據(jù)不允許重復(fù)。

(3)都實(shí)現(xiàn)了list接口。

(4)都是通過數(shù)組實(shí)現(xiàn)的。

(5)數(shù)組進(jìn)行復(fù)制、移動(dòng)、代價(jià)比較高,因此,適合隨機(jī)查詢和遍歷,不適合插入和刪除。

2.不同點(diǎn)

(1)ArrayList屬于線程不安全(線程不同步)即當(dāng)多線程進(jìn)行對ArrayList集合的操作時(shí),有可能對數(shù)據(jù)進(jìn)行不正確的操作。如果只有一個(gè)線程會(huì)訪問到集合,那最好是使用ArrayList,因?yàn)樗豢紤]線程安全,效率會(huì)高些。

(2)Vector是線程安全的(同步線程)即當(dāng)在同一時(shí)刻只能有一個(gè)線程進(jìn)行對Vector集合的操作時(shí),但是Vector要做到線程同步,需要大量的花費(fèi),可能消耗大量的內(nèi)存或者CPU。如果有多個(gè)線程會(huì)訪問到集合,那最好是使用Vector,因?yàn)椴恍枰覀冊偃タ紤]和編寫線程安全的代碼。

(3)ArrayList在內(nèi)存不夠時(shí)默認(rèn)擴(kuò)展1.5倍,Vector是默認(rèn)擴(kuò)展1倍。

(4)Vector提供indexOf(object,start)接口,ArrayList沒有。

3.實(shí)例代碼對比

ArrayList中:

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; // 此行沒看出來用處,不知道開發(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中:

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);
 
   
 
    }
 
   
 
}

感謝各位的閱讀,以上就是“Java Vector和ArrayList的異同點(diǎn)是什么”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對Java Vector和ArrayList的異同點(diǎn)是什么這一問題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!

分享名稱:JavaVector和ArrayList的異同點(diǎn)是什么
當(dāng)前網(wǎng)址:http://bm7419.com/article4/iihiie.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制開發(fā)、網(wǎng)站維護(hù)、虛擬主機(jī)定制網(wǎng)站、動(dòng)態(tài)網(wǎng)站、小程序開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站建設(shè)網(wǎng)站維護(hù)公司