這篇文章主要講解了“Java Vector和ArrayList的異同點(diǎn)是什么”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)“Java Vector和ArrayList的異同點(diǎn)是什么”吧!
成都創(chuàng)新互聯(lián)公司專注于企業(yè)營(yíng)銷型網(wǎng)站建設(shè)、網(wǎng)站重做改版、通道網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、HTML5建站、成都商城網(wǎng)站開(kāi)發(fā)、集團(tuán)公司官網(wǎng)建設(shè)、成都外貿(mào)網(wǎng)站建設(shè)、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁(yè)設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為通道等各大城市提供網(wǎng)站開(kāi)發(fā)制作服務(wù)。
1.相同點(diǎn)
(1)都是有序集合。
(2)數(shù)據(jù)不允許重復(fù)。
(3)都實(shí)現(xiàn)了list接口。
(4)都是通過(guò)數(shù)組實(shí)現(xiàn)的。
(5)數(shù)組進(jìn)行復(fù)制、移動(dòng)、代價(jià)比較高,因此,適合隨機(jī)查詢和遍歷,不適合插入和刪除。
2.不同點(diǎn)
(1)ArrayList屬于線程不安全(線程不同步)即當(dāng)多線程進(jìn)行對(duì)ArrayList集合的操作時(shí),有可能對(duì)數(shù)據(jù)進(jìn)行不正確的操作。如果只有一個(gè)線程會(huì)訪問(wèn)到集合,那最好是使用ArrayList,因?yàn)樗豢紤]線程安全,效率會(huì)高些。
(2)Vector是線程安全的(同步線程)即當(dāng)在同一時(shí)刻只能有一個(gè)線程進(jìn)行對(duì)Vector集合的操作時(shí),但是Vector要做到線程同步,需要大量的花費(fèi),可能消耗大量的內(nèi)存或者CPU。如果有多個(gè)線程會(huì)訪問(wèn)到集合,那最好是使用Vector,因?yàn)椴恍枰覀冊(cè)偃タ紤]和編寫(xiě)線程安全的代碼。
(3)ArrayList在內(nèi)存不夠時(shí)默認(rèn)擴(kuò)展1.5倍,Vector是默認(rèn)擴(kuò)展1倍。
(4)Vector提供indexOf(object,start)接口,ArrayList沒(méi)有。
3.實(shí)例代碼對(duì)比
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; // 此行沒(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中:
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)過(guò)本文的學(xué)習(xí)后,相信大家對(duì)Java Vector和ArrayList的異同點(diǎn)是什么這一問(wè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://jinyejixie.com/article4/iihiie.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制開(kāi)發(fā)、網(wǎng)站維護(hù)、虛擬主機(jī)、定制網(wǎng)站、動(dòng)態(tài)網(wǎng)站、小程序開(kāi)發(fā)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)