问题描述
例如:用foreach遍历容器时,并同时对容器进行修改操作,会出现ConcurrentModificationException()异常
public class Ttest {
Vector<String> vectors=new Vector<String>();
public Ttest(){
vectors.add("a");
vectors.add("b");
vectors.add("c");
vectors.add("d");
vectors.add("e");
vectors.add("f");
}
public static void main(String[] args) {
Ttest ttest=new Ttest();
for (String vector : ttest.vectors) {
if (vector.equals("b")){
System.out.println("删除"+vector);
ttest.vectors.remove(vector);
}else {
System.out.println(vector);
}
}
// for (int i=0;i<ttest.vectors.size();i++){
// String vector=ttest.vectors.get(i);
// if (vector.equals("b")){
// System.out.println("删除"+vector);
// ttest.vectors.remove(vector);
// }else {
// System.out.println(vector);
// }
// }
}
}
打印结果
a
删除b
Exception in thread "main" java.util.ConcurrentModificationException at java.util.Vector$Itr.checkForComodification(Vector.java:1212) at java.util.Vector$Itr.next(Vector.java:1165) at com.example.tankgame.thread.Ttest.main(Ttest.java:24)
原因分析:
用foreach进行容器遍历时,其本质还是用的迭代器遍历容器
迭代器初始化是在Itr()中,会有int expectedModCount = modCount;
每进行一次遍历都会checkForComodification() 去检查expectedModCount 与modCount是否相等
而在遍历中进行修改(删除/新增)会使得modCount++; 此时checkForComodification()去执行发现expectedModCount != modCount 就会抛出异常ConcurrentModificationException()
遍历调用到的方法(force step into下跟 )
for (String vector : vectors)->iterator()->new Itr()
->int expectedModCount = modCount;
->hasNext()
->next() ->checkForComodification
->elementData
借鉴了该篇文章,解决了我的困惑,十分感谢
https://blog.csdn.net/qq_46312987/article/details/122383715