JAVA 循環刪除list中元素的方法總結
摘要:介紹List集合實現元素邊遍歷邊刪除的方法,例如removeIf和迭代器iterator.remove()等。
綜述
??List集合是我們開發中經常使用到的一種集合形式,有時候會遇到在遍歷List集合時需要刪除指定的元素。但在根據條件使用for循環或者增強的for循環遍歷刪除某些元素時卻不能隨心所欲地使用remove函數,我們今天便從實現層面討論下原因以及Iterator的相關知識。伸手黨或者資深大佬看完下面的總結就行,不必閱讀全文。
??比如,有一個字符串類型的List,包含四個元素:“軟件”、“del”、“開發”、“領路人”,我們要實現的是在遍歷這個集合時,刪除長度為2的字符串元素。要怎么做呢?有如下幾種方法:
- for循環倒序刪除
- iterator遍歷刪除
- 使用removeIf刪除
for循環倒序刪除
順序刪除時,會報錯,提示:Exception in thread "main" java.util.ConcurrentModificationException:
for(int i=0;i < list.size();i++){
if(list.get(i).equals("del"))
list.remove(i);
}
??這種方式的問題在于,刪除某個元素后,list的大小發生了變化,而數組下標也在變化,所以會導致在遍歷的時候漏掉某些元素。比如刪除第1個元素后,繼續根據角標訪問第2個元素時,因為刪除的關系后面的元素都往前移動了一位,所以實際訪問的是第3個元素。因此,這種方式可以用在刪除特定的一個元素后就終止循環時使用,尤其不適合循環刪除多個元素時使用。
結論:for循環正序刪除的問題在于,刪除某個元素后,其后元素的數組下標將向前挪一位,所以會導致在遍歷的時候漏掉被刪除元素的后一個元素。解決辦法:從list最后一個元素開始從后向前遍歷。
/**
* 倒序刪除:刪除list集合中屬性全為null的對象
*
*/
private void removeEmptyObjectInList(List<? extends Object> list) {
if (null != list && list.size() > 0) {
for (int i = list.size() - 1; i >= 0; i--) {
if(list.get(i) == null){
list.remove(i);
}
}
}
}
public static void main(String[] args) {
List<String> list = new LinkedList<String>();
list.add("a");
list.add("b");
list.add("c");
list.add("d");
list.add("e");
for(int i=0;i<list.size();i++){
System.out.println("即將刪除的元素:"+list.get(i));
list.remove(i);
i--;
}
}
當要針對角標進行元素的remove時,使用倒序遍歷的方式最為妥當。
使用foreach刪除
使用增強型for循環 foreach 刪除指定元素:
for(String x:list){
if(x.equals("del")){
System.out.println("即將刪除的元素:"+x);
list.remove(x);
}
}
??這種方式的問題在于,刪除元素后繼續循環會拋異常ConcurrentModificationException,因為元素在使用的時候發生了并發修改,導致異常被拋出。但是刪除完畢馬上使用break跳出,則不會觸發報錯。
iterator遍歷刪除
??下面提供一個用迭代器在遍歷List集合時刪除元素的方法:
Iterator it = list.iterator();
while(it.hasNext()){
String x = it.next();
if(x.equals("del")){
System.out.println("即將刪除的元素:"+x);
it.remove();
}
}
??能達到預期效果嗎?我們執行后驗證一下就知道了。在控制臺可以看到如下結果,說明已經被刪除:
即將刪除的元素:del
??這種方式可以正常的循環及刪除。但要注意的是,調用iterator的remove方法時,如果用list的remove方法同樣會報上面提到的ConcurrentModificationException錯誤。
使用removeIf刪除
??在 Java 8 中,Collection及其子類新加入了removeIf函數,作用是按照特定規則過濾集合中的元素。語法為:
arraylist.removeIf(Predicate<E> filter)
??參數說明:filter - 過濾器,判斷元素是否被刪除,如果元素被刪除則filter返回 true。實例,刪除等于del的元素:
list.removeIf(s-> s.equals("del"));
結束語
??總結:
??(1)刪除list中某一個元素時,可以使用上述幾種方式中的任意一種。
??(2)循環刪除list中多個元素時,應該使用for循環倒序刪除、迭代器iterator或者removeIf。
??以上就是小編分享給各位程序猿的全部內容了,希望各位讀后有所收獲,也希望大家多多支持樓蘭胡楊。
Buy me a coffee. ?Get red packets.
浙公網安備 33010602011771號