java ArrayList中的remove方法介紹
先看一段代碼,看看自定義的ArrayList中的remove設(shè)計是否有問題。
public class MyArrayList { private Object[] mData = new Object[0]; private int mSize = 0; // 刪除第i個元素 public void remove(int i) { if (i < 0 || i >= mSize) return; for (int index = i; index < mSize - 1; index++) { mData[index] = mData[index + 1]; } --mSize; } // ... 其他方法略 }
走進源碼:
針對remove,有兩種方式實現(xiàn)
(1)根據(jù)位置刪除,代碼如下所示:
public E remove(int index) { rangeCheck(index); modCount++; E oldValue = elementData(index); int numMoved = size - index - 1; if (numMoved > 0) System.arraycopy(elementData, index+1, elementData, index, numMoved); elementData[--size] = null; // clear to let GC do its work return oldValue; }
實現(xiàn)步驟:
檢查所要移除的位置是否落在數(shù)組元素長度之內(nèi)。
修改次數(shù)+1把需要刪除的元素賦給oldValue,一遍方法返回舊元素numMoved計算出的是刪除元素后需要移動的元素數(shù)。
當numMoved>0 說明刪除元素后需要把后面的元素往前移動。
當numMoved<0 時,說明刪除的元素為最后一個元素。
直接把最后一個位置置空。(分析重點:將最后的位置要設(shè)置為空,讓垃圾回收器回收 ,防止對象游離)返回被刪值
(2)根據(jù)內(nèi)容刪
參考資料:
public boolean remove(Object o) { if (o == null) { for (int index = 0; index < size; index++) if (elementData[index] == null) { fastRemove(index); return true; } } else { for (int index = 0; index < size; index++) if (o.equals(elementData[index])) { fastRemove(index); return true; } } return false; }
其中的fastRemove,代碼如下:
private void fastRemove(int index) { modCount++; int numMoved = size - index - 1; if (numMoved > 0) System.arraycopy(elementData, index+1, elementData, index, numMoved); elementData[--size] = null; // clear to let GC do its work }
實現(xiàn)步驟:
因為對象是否相等需要使用equals方法,但是空對象不能使用equals方法比較。
因此需要先判斷傳入的對象是否為空。
為空時 使用==來尋找數(shù)組中空對象并刪除。不為空時,便使用equals遍歷尋找來刪除相應(yīng)對象。
OK,ArrayList的第一階段的研究到此結(jié)束,針對開頭的問題,已經(jīng)找到了答案。
remove的設(shè)計有問題,–mSize;之后需要把mData[–mSize]=null;讓垃圾回收器回收 ,防止對象游離。
未來有時間的研究方向大概如下,
?ArrayList?
? VS ??LinkedList?
?
如何自定義一個??ArrayList?
?
ArrayList的研究有時間可以再深入了解一下。網(wǎng)上的文章已經(jīng)很多,在此不在贅述。旨在加深自我認知,上述大家如有疑問,歡迎PK。
到此這篇關(guān)于java ArrayList中的remove方法介紹的文章就介紹到這了,更多相關(guān)java ArrayList中的remove內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Intellj Idea中的maven工程Java文件顏色不對,未被識別的解決
這篇文章主要介紹了Intellj Idea中的maven工程Java文件顏色不對,未被識別的解決,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-08-08java實現(xiàn)隨機森林RandomForest的示例代碼
本篇文章主要介紹了java實現(xiàn)隨機森林RandomForest的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-08-08Springboot使用Redis中ZSetOperations實現(xiàn)博客訪問量
在日常的網(wǎng)站使用中,經(jīng)常會碰到頁面的訪問量,本文主要介紹了Springboot使用Redis中ZSetOperations實現(xiàn)博客訪問量,具有一定的參考價值,感興趣的可以了解一下2024-01-01java.io.IOException:?UT010029:?Stream?is?closed異常分析及解決
這篇文章主要給大家介紹了關(guān)于java.io.IOException:?UT010029:?Stream?is?closed異常分析及解決辦法,文中通過代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考借鑒價值,需要的朋友可以參考下2024-02-02mybatis?plus新增(insert)數(shù)據(jù)獲取主鍵id的問題
這篇文章主要介紹了mybatis?plus新增(insert)數(shù)據(jù)獲取主鍵id的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-03-03