1、從存儲(chǔ)數(shù)據(jù)結(jié)構(gòu)分析

(推薦教程:java入門(mén)教程)
ArrayList:數(shù)組
Vector:數(shù)組
LinkedList:雙向鏈表
數(shù)組:可以根據(jù)下標(biāo)快速查找,所以大部分情況下,查詢(xún)快。
但是如果要進(jìn)行增刪操作的時(shí)候,會(huì)需要移動(dòng)修改元素后面的所有元素,所以增刪的開(kāi)銷(xiāo)比較大,數(shù)組的對(duì)增刪操作的執(zhí)行效率低。而采用數(shù)組作為數(shù)據(jù)存儲(chǔ)結(jié)構(gòu)的ArrayList、Vector也存在這些特性,查詢(xún)速度快(可以根據(jù)下標(biāo)直接取,比迭代查找更快),增刪慢。
鏈表:增加和刪除元素方便,增加或刪除一個(gè)元素,僅需處理結(jié)點(diǎn)間的引用即可。就像人手拉手連成一排,要增加或刪除某個(gè)人只要附近的兩個(gè)人換一個(gè)人牽手,對(duì)已經(jīng)牽好手的人沒(méi)影響。無(wú)論在哪里換人耗費(fèi)的資源和時(shí)間都是一樣的。
但是查詢(xún)不方便,需要一個(gè)個(gè)對(duì)比,無(wú)法根據(jù)下標(biāo)直接查找。而采用鏈表結(jié)構(gòu)存儲(chǔ)的LinkedList也有這些特性,增刪方便,查詢(xún)慢(指的是隨機(jī)查詢(xún),不是順序查詢(xún))。
2、從繼承上分析
它們都實(shí)現(xiàn)了List接口,也就是說(shuō)都實(shí)現(xiàn)了get(int location)、remove(int location)等“根據(jù)索引值來(lái)獲取、刪除節(jié)點(diǎn)的函數(shù)”。
(視頻教程推薦:java視頻教程)
數(shù)組結(jié)構(gòu)根據(jù)下標(biāo)取值很容易,LinkedList雙向列表的實(shí)現(xiàn)也比較簡(jiǎn)單,通過(guò)計(jì)數(shù)索引值實(shí)現(xiàn),從鏈表長(zhǎng)度的1/2開(kāi)始查找,下標(biāo)大了就從表頭開(kāi)始找,小了就從表尾開(kāi)始找。
3、從并發(fā)安全上分析
Vector:線(xiàn)程安全
ArrayList:非線(xiàn)程安全
LinkedList:非線(xiàn)程安全
4、數(shù)據(jù)增長(zhǎng)分析
Vector:缺省的情況下,增長(zhǎng)為原數(shù)組長(zhǎng)度的一倍。說(shuō)到缺省,說(shuō)明他其實(shí)是可以自主設(shè)置初始化大小的。
ArrayList:自動(dòng)增長(zhǎng)原數(shù)組的50%。
分享標(biāo)題:ArrayList、LinkedList與Vector三者有什么區(qū)別
URL鏈接:http://chinadenli.net/article46/cjeshg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供云服務(wù)器、商城網(wǎng)站、網(wǎng)站策劃、網(wǎng)站建設(shè)、全網(wǎng)營(yíng)銷(xiāo)推廣、網(wǎng)頁(yè)設(shè)計(jì)公司
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容