首先,使用簡單的for循環時,list.remove()肯定是沒問題的,只要注意一下下標別越界就行。
示例代碼:
List<String> ll = new ArrayList<String>();
ll.add("1");
ll.add("2");
ll.add("3");
ll.add("4");
ll.add("5");
for(int i=0;i<5;i++){
if(i==2){
ll.remove(i);
}
}
for (String s : ll) {
System.out.println(s);
}
運行結果 1 2 4 5
但是這種方法不能用於刪除多個元素,如下代碼:
List<String> strlist = new ArrayList<String>();
strlist.add("1"); strlist.add("2"); strlist.add("3"); strlist.add("4"); strlist.add("5"); strlist.add("6"); for(int i = 0 ;i< 5;i++){ if(i == 1 || i ==3){ strlist.remove(i); } } for(String s : strlist){ System.out.println(s); }
運行結果是 1 3 4 6
因為元素刪除后,后邊元素前移了,刪除的第四個元素,實際上是原來的第五個元素:5。
還有一種情況,也容易犯渾:
List<String> strlist = new ArrayList<String>();
strlist.add("1"); strlist.add("2"); strlist.add("2"); strlist.add("3"); strlist.add("4"); strlist.add("5"); for(int i = 0 ;i< 5;i++){ if("2".equals(strlist.get(i))){ strlist.remove(i); } } for(String s : strlist){ System.out.println(s); }
該段代碼運行結果, 1 2 3 4 5 ,因為元素刪除后前移,正好下次循環時把第二個‘2’漏掉了。
報ConcurrentModificationException異常的情況一般是因為在使用了迭代器iterator的情況下,沒使用iterator.remove(),而是使用list.remove()造成的,推薦做法如下:
示例代碼:
1 //准備數據
2 List<Student> list = new ArrayList<>();
3 list.add(new Student("1")); 4 list.add(new Student("2")); 5 list.add(new Student("3")); 6 list.add(new Student("4")); 7 8 //遍歷刪除 9 Iterator<Student> iterator = list.iterator(); 10 while (iterator.hasNext()) { 11 Student student = iterator.next(); 12 if ("1".equals(student.getId())) { 13 iterator.remove();//使用迭代器的刪除方法刪除 14 } 15 }
在使用foreach遍歷時,foreach內部實現實際上還是使用了迭代器,所以會報錯。閱讀源碼可以發現,在刪除倒數第二個元素時不會報錯,具體原因可以看:https://blog.csdn.net/bimuyulaila/article/details/52088124
另:調用Arrays.asList()生產的List不可以使用add,remove,這是由Arrays.asList() 返回的市Arrays的內部類ArrayList, 而不是java.util.ArrayList。Arrays的內部類ArrayList和java.util.ArrayList都是繼承AbstractList,remove、add等方法AbstractList中是默認throw UnsupportedOperationException而且不作任何操作。詳細介紹