您好,登錄后才能下訂單哦!
本篇文章為大家展示了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ù),如下:
既然是雙向鏈表,那么必定存在一種數(shù)據(jù)結(jié)構(gòu)——我們可以稱之為節(jié)點(diǎn),節(jié)點(diǎn)實(shí)例保存業(yè)務(wù)數(shù)據(jù),前一個(gè)節(jié)點(diǎn)的位置信息和后一個(gè)節(jié)點(diǎn)位置信息,如下圖所示:
上述內(nèi)容就是ArrayList和LinkedList底層實(shí)現(xiàn)原理是什么,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注億速云行業(yè)資訊頻道。
免責(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)容。