ArrayList和LinkedList對比

~、結(jié)構(gòu)

ArrayList位數(shù)組結(jié)構(gòu),LinkedList為雙向鏈表結(jié)構(gòu)。

~、空間

ArrayList有固定容量,超出容量后需要擴容,在數(shù)組尾部可能保存有占位的null元素

LinkedList無固定容量,但每個元素都放在節(jié)點中,每個節(jié)點都有2個額外的定位指針(prev 和 next),第一個和最后一個節(jié)點的prev和next都指向null

~、方法及效率對比

—:add

1、add()

ArrayList在數(shù)組的最后追加,額外操作僅僅是數(shù)組滿了的擴容

LinkedList在鏈表的最后追加同addLast(),每次創(chuàng)建一個新節(jié)點(新節(jié)點的prev指針指向之前的最后一個節(jié)點last),last的next指針指向新節(jié)點。每次都需給2個指針賦值。效率不如ArrayList

2、add(int index, E element)

ArrayList在數(shù)組的指定index位置添加元素element,每次都需調(diào)用System.arraycopy() 拷貝數(shù)組

LinkedList只是創(chuàng)建一個prev指針指向index前一個元素,next指針指向index元素的節(jié)點,并將index前節(jié)點的next指針和index節(jié)點的prev指針指向新節(jié)點。與前面的在最后添加差不多,此時效率要遠遠高于ArrayList

3、在結(jié)構(gòu)最前面添加,ArrayList只能用 add(0, e)。而LinkedList除add(0, e)外還可以用addFirst(e)。同樣LinkedList效率高于ArrayList

—:get

1、get(int index)

ArrayList直接取數(shù)組下標得到元素值

LinkedList需要遍歷鏈表取到index位置的節(jié)點,再得到節(jié)點的item值。效率受鏈表長度和index在鏈表位置的影響

2、get遍歷

for遍歷

ArrayList數(shù)組長度及循環(huán)次數(shù),一個元素只循環(huán)一次。LinkedList每取一個數(shù)都重新遍歷鏈表,一個元素最多遍歷 鏈表長/2次。

foreach遍歷

先將集合轉(zhuǎn)Iterator,循環(huán)次數(shù)都為元素的個數(shù)。

ArrayList2種方式都可,LinkedList要求使用foreach

—:remove

1、remove(int index)

ArrayList刪除指定下標的元素,需調(diào)用System.arraycopy()函數(shù),再將最后一個元素賦null

LinkedList刪除指定下標的節(jié)點,改變index節(jié)點的prev節(jié)點的next為index的next,index的next節(jié)點的prev為index的prev,再清理index節(jié)點的item為null。效率也比ArrayList好。

2、remove(Object o)

刪除數(shù)組或鏈表中第一次出現(xiàn)的與o相等的元素,先查找再刪除,刪除步驟同第一點。

3、remeve(),removeFirst(),removeLast()

3個方法都只是LinkedList所有。removeFirst()和remove()方法刪除第一個節(jié)點。removeLast()刪除最后一個節(jié)點。

—:set

1、set(int index, E element)

替換index位置的元素為element。

ArrayList直接取數(shù)組下標賦值。

LinkedList首先遍歷鏈表取到index位置的節(jié)點,再將節(jié)點的item賦值。如果鏈表比較大切index在鏈表中間位置會很浪費時間。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容