1.1java.util.ConcurrentModificationException 产生背景
操作: 想要在循环遍历的过程中删除集合中的元素。
场景: 在项目的代码中,遍历的方式是增强 for 循环,在底层使用的也是迭代器。但是我在删除的时候是通过ArrayList的remove方法去操作的,不是Itr内部的那个删除方法去操作的。
原因: ArrayList的remove方法修改的变量是继承自AbstractList的变量modCount;而Itr的remove方法修改的是自身的变量expectedModCount。这两个变量的作用都是记录修改次数的。所以,在用ArrayList的remove方法进行删除操作以后,Itr里面的expectedModCount会与ArrayList的modCount进行比较,二者不相等,所以会抛错。
1.2错误案例
import java.util.ArrayList;
class MyTest{
public static void main(String[] args){
ArrayList<Integer> arr = new ArrayList<Integer>();
for(int i=0; i<10; i++){
arr.add(i);
}
for(Integer i: arr){
if(i == 5){
arr.remove(i);
}
else{
System.out.println(i);
}
}
}
}
1.3解决方法
1.3.1改成Iterator的迭代方式
用内部类Itr的remove方法来删除,保证一致性:
案例:
import java.util.ArrayList;
class MyTest{
public static void main(String[] args){
ArrayList<Integer> arr = new ArrayList<Integer>();
for(int i=0; i<10; i++){
arr.add(i);
}
for(Iterator<Integer> it=arr.iterator(); it.hasNext();){
Integer i = it.next();
if(i == 5){
it.remove();
}
else{
System.out.println(i);
}
}
}
}
1.3.1每次删除的时候都让i减1
案例:
import java.util.ArrayList;
class MyTest{
public static void main(String[] args){
ArrayList<Integer> arr = new ArrayList<Integer>();
for(int i=0; i<10; i++){
arr.add(i);
}
for(int i=0; i<arr.size(); i++){
if(i == 5){
arr.remove(i);
i -= 1;
}
else{
System.out.println(i);
}
}
}
}