iterator并发修改异常以及解决方法

iterator并发修改异常

并发修改异常

​ 在用迭代器遍历容器的时候,试图去修改容器中的元素,可能会引起并发修改异常(遍历的时候,相当于一个指针从0索引开始移动,当试图修改某个数据时,系统无法去操作这个指针)

//  ConcurrentModificationException

产生原因

迭代器是依赖于集合而存在的,在判断成功之后,集合当中增加了新的元素,而迭代器却不知道,所以就报错了,这个就叫并发修改异常。

import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;

public class ListIteratorDemo2 {
	public static void main(String[] args) {
		//创建集合对象
		List list = new ArrayList();
						
		//添加对象
		list.add("hello");
		list.add("world");
		list.add("java");
		
		//迭代器遍历
		Iterator it = list.iterator();
		while(it.hasNext()){
			String string = (String) it.next();
			//ConcurrentModificationException
			if(string.equals("world")){
				list.add("javaee");
			}
		}
		
		System.out.println("list:"+list);
	}
}

所报的错误:

Exception in thread "main" java.util.ConcurrentModificationException
	at java.util.AbstractList$Itr.checkForComodification(AbstractList.java:372)
	at java.util.AbstractList$Itr.next(AbstractList.java:343)
	at cn.hhy.test_04.ListIteratorDemo2.main(ListIteratorDemo2.java:23)

也就是迭代器遍历元素的时候,集合不能进行修改元素。

解决方案

  • 1.使用listIterator迭代器迭代元素,迭代器修改元素:元素跟在刚才迭代元素之后
ListIterator lit = list.listIterator();
while(lit.hasNext()){
	String string = (String) lit.next();
	//ConcurrentModificationException
	if(string.equals("world")){
		lit.add("javaee");
	}
}
  • 2.集合遍历元素,集合修改元素(普通的for):元素跟在集合最后一个元素之后。
for(int i=0;i<list.size();i++){
	String s = (String)list.get(i);
	if(s.equals("world")){
		list.add("javaee");
	}
}
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Java的集合框架中,如果多个线程同时对同一个集合进行修改操作,就有可能会引发并发修改异常(ConcurrentModificationException)。这个异常通常在使用迭代器遍历集合的过程中出现。 当一个线程正在使用迭代器遍历集合时,如果其他线程对集合进行了结构性修改(比如添加、删除元素),就会导致迭代器的fail-fast机制抛出并发修改异常。这是因为迭代器在遍历过程中会通过内部的modCount字段记录集合结构修改的次数,一旦发现结构修改次数与迭代器创建时不一致,就会抛出并发修改异常。 以下是一个可能引发并发修改异常的例子: ```java List<String> list = new ArrayList<>(); list.add("元素1"); list.add("元素2"); list.add("元素3"); Iterator<String> iterator = list.iterator(); while (iterator.hasNext()) { String element = iterator.next(); if (element.equals("元素2")) { list.remove(element); // 并发修改集合 } } ``` 在上述代码中,一个线程正在使用迭代器遍历集合,另一个线程在遍历过程中删除了一个元素,导致并发修改异常。 为了避免并发修改异常,可以采取以下措施: - 使用线程安全的集合类,如`ConcurrentHashMap`、`CopyOnWriteArrayList`等。 - 在多线程环境下,对需要修改集合的操作进行同步,确保只有一个线程在修改集合。 - 在使用迭代器遍历集合时,不要同时进行修改操作,可以使用迭代器的remove()方法进行删除操作。 希望能够解答你的问题!如果还有任何疑问,请随时提出。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值