溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

ArrayList和LinkedList底層實(shí)現(xiàn)原理是什么

發(fā)布時(shí)間:2021-06-04 17:12:10 來源:億速云 閱讀:250 作者:Leah 欄目:編程語言

本篇文章為大家展示了ArrayList和LinkedList底層實(shí)現(xiàn)原理是什么,內(nèi)容簡明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。

1、說一下 ArrayList 底層實(shí)現(xiàn)方式?

①ArrayList 通過數(shù)組實(shí)現(xiàn),一旦我們實(shí)例化 ArrayList 無參數(shù)構(gòu)造函數(shù)默認(rèn)為數(shù)組初始化長度為 10

②add 方法底層實(shí)現(xiàn)如果增加的元素個(gè)數(shù)超過了 10 個(gè),那么 ArrayList 底層會(huì)新生成一個(gè)數(shù)組,長度為原數(shù)組的 1.5 倍+1,然后將原數(shù)組的內(nèi)容復(fù)制到新數(shù)組當(dāng)中,并且后續(xù)增加的內(nèi)容都會(huì)放到新數(shù)組當(dāng)中。當(dāng)新數(shù)組無法容納增加的元素時(shí),重復(fù)該過程。是一旦數(shù)組超出長度,就開始擴(kuò)容數(shù)組。

擴(kuò)容數(shù)組調(diào)用的方法

Arrays.copyOf(objArr, objArr.length + 1);

2、說一下 LinkedList 底層實(shí)現(xiàn)方式?

LinkedList 底層的數(shù)據(jù)結(jié)構(gòu)是基于雙向循環(huán)鏈表的,且頭結(jié)點(diǎn)中不存放數(shù)據(jù),如下:

ArrayList和LinkedList底層實(shí)現(xiàn)原理是什么

既然是雙向鏈表,那么必定存在一種數(shù)據(jù)結(jié)構(gòu)——我們可以稱之為節(jié)點(diǎn),節(jié)點(diǎn)實(shí)例保存業(yè)務(wù)數(shù)據(jù),前一個(gè)節(jié)點(diǎn)的位置信息和后一個(gè)節(jié)點(diǎn)位置信息,如下圖所示:

ArrayList和LinkedList底層實(shí)現(xiàn)原理是什么

上述內(nèi)容就是ArrayList和LinkedList底層實(shí)現(xiàn)原理是什么,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI