foreach循环删除集合中的元素出现ConcurrentModificationException异常

本文详细阐述了在使用foreach遍历集合时直接对其执行add或remove操作会导致ConcurrentModificationException异常的问题,并通过代码实例进行了验证。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

------------------------------------ 题记

在使用foreach遍历一个集合并在循环内部对该集合执行add或remove操作会引发ConcurrentModificationException异常。这是很早之前遇到的一个问题,当时查了下资料也没做记录和测试,所以今天便做了个测试,代码中有详细的解释。

------------------------------------ 代码

package collection;

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

public class Test {
	public static void main(String[] args) {
		//---------声明数组
		List<Integer> list = new ArrayList<Integer>();
		list.add(0);
		list.add(1);
		list.add(2);
		
		//foreach测试
		for(int n : list){
			System.out.println(n);
			list.remove(0);
//			if(n == 2) list.set(0,4);
			if(n == 2) list.add(3, 4);
//			if(n == 2) list.remove(1);
		}
		
		//iterator测试(foreach原理便是iterator)
//		for(Iterator<Integer> iterator = list.iterator(); iterator.hasNext();){
//			System.out.println("------------开始");
//			System.out.println("指针移动!");
//			int num = iterator.next();
//			System.out.println("打印当前元素:" + num);
//			if(num == 0) {
//				System.out.println("执行删除!");
//				list.remove(0);
//			}
//		}
		
		/*
		 * 整个过程中,iterator的指针只进行过一次定义,所以它的指针会保持为第一时的状态,
		 * 然而在循环执行过程中,list集合发生了长度上的变动,
		 * 所以对应的iterator指针也应该做相应的调整,因为物理位置发生了改变,
		 * 但可惜的是,iterator还是保持第一次声明时的状态,
		 * 所以这个时候iterator.next()指针所保持的物理地址已经不符合当前要求了,
		 * 故会抛出java.util.ConcurrentModificationException该异常。
		 */
	}
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值