方式一
jdk 1.8 以后刪除:
List<String> strList2 = new ArrayList<>(); |
方式二(使用迭代器的remove方法)
在使用迭代器遍歷時,可使用迭代器的remove方法,因為Iterator的remove方法中 有如下的操作: expectedModCount = modCount; 所以避免了ConcurrentModificationException的異常。代碼如下: public void testDel() { List<Integer> list = Lists.newArrayList(); list.add(1); list.add(2); list.add(2); list.add(2); Iterator<Integer> iterator = list.iterator(); while (iterator.hasNext()) { Integer integer = iterator.next(); if (integer == 2) iterator.remove(); } } |
方式三(倒序遍歷刪除)
public void testDel() { List<Integer> list = Lists.newArrayList(); list.add(1); list.add(2); list.add(2); list.add(2); list.add(2); for(int i=list.size()-1;i>=0;i--){ if(list.get(i)==2){ list.remove(i); } } } 結果: list = [1] 所以list的size改變並沒有對遍歷造成影響,且元素的前移也不會對倒序遍歷有影響。 其實JAVA中循環遍歷list有三種方式for循環、增強for循環(也就是常說的foreach循環)、iterator遍歷。 |
方式四 (for循環遍歷list)
for(int i=0;i<list.size();i++){ if(list.get(i).equals("del")) list.remove(i); }
這種方式的問題在於,刪除某個元素后,list的大小發生了變化,而你的索引也在變化,所以會導致你在遍歷的時候漏掉某些元素。比如當你刪除第1個元素后,繼續根據索引訪問第2個元素時,因為刪除的關系后面的元素都往前移動了一位,所以實際訪問的是第3個元素。因此,這種方式可以用在刪除特定的一個元素時使用,但不適合循環刪除多個元素時使用。
方式五(增強for循環)
for(String x:list){ if(x.equals("del")) list.remove(x); }
這種方式的問題在於,刪除元素后繼續循環會報錯誤信息ConcurrentModificationException,因為元素在使用的時候發生了並發的修改,導致異常拋出。但是刪除完畢馬上使用break跳出,則不會觸發報錯。
方式六(增強for循環)
for(String x:list){ if(x.equals("del")) list.remove(x); }
這種方式的問題在於,刪除元素后繼續循環會報錯誤信息ConcurrentModificationException,因為元素在使用的時候發生了並發的修改,導致異常拋出。但是刪除完畢馬上使用break跳出,則不會觸發報錯。
方式七(iterator遍歷)
Iterator<String> it = list.iterator(); while(it.hasNext()){ String x = it.next(); if(x.equals("del")){ it.remove(); } }
這種方式可以正常的循環及刪除。但要注意的是,使用iterator的remove方法,如果用list的remove方法同樣會報上面提到的ConcurrentModificationException錯誤。
總結:
(1)循環刪除list中特定一個元素的,可以使用七種方式中的任意一種,但在使用中要注意上面分析的各個問題。
(2)循環刪除list中多個元素的,應該使用迭代器iterator方式。
所以在對list或者hashmap遍歷時候進行元素刪增操作時,一定要驗證下,調試才發現前面幾種方式是有問題的,不是異常,就是效果沒達到預期。到線上會出大問題。所以整理了下,推薦最后第一種方式!