并发修改异常
并发修改异常
- ConcurrentModificationException:当不允许这样的修改时,可以通过检测到对象的并发修改的方法来抛出此异常
遍历集合,得到每一个元素,看有没有"world"这个元素,如果有,就添加一个"javaee"元素,请写代码实现
package com.gather.list;
//并发修改异常
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
public class ListDemo03 {
public static void main(String[] args) {
List<String> list=new ArrayList<String>();
list.add("hello");
list.add("world");
list.add("java");
Iterator<String> it = list.iterator();
while (it.hasNext()){
String s = it.next();
if (s.equals("world")) {
list.add("javaee");
}
}
System.out.println(list);
}
}

此代码运行逻辑没有问题,但是在运行时出现并发修改异常,查看JDK帮助文档原因是使用迭代器遍历集合时预期修改值和实际修改值进行了判断,导致预期修改值和实际修改值不一致
package com.gather.list;
//并发修改异常
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
public class ListDemo03 {
public static void main(String[] args) {
List<String> list=new ArrayList<String>();
list.add("hello");
list.add("world");
list.add("java");
for (int i = 0; i < list.size(); i++) {
String s = list.get(i);
if (s.equals("world")){
list.add("javaee");
}
}
System.out.println(list);
}
}

此代码在遍历集合时使用了普通的for循环,for循环里使用的是get()方法,而get()方法在遍历集合时没有进行预期修改值和实际修改值的判断,所以使用普通的for循环避免了并发修改异常的发生
- 产生的原因:迭代器在遍历的过程中,通过集合对象修改了集合中元素的长度,造成了迭代器获取元素中判断预期修改值和实际修改值不一致
文章讲述了在Java编程中遇到的并发修改异常,即ConcurrentModificationException。当使用迭代器遍历集合并尝试修改集合内容时,会出现该异常。提供了一个示例代码,展示了在迭代过程中添加元素导致异常的情况。为避免这个问题,文章推荐使用普通的for循环代替迭代器,因为for循环不会检查集合的修改状态,从而避免了异常的发生。

被折叠的 条评论
为什么被折叠?



