Map遍历时报ConcurrentModificationException解决方法

本文介绍了遍历HashMap过程中出现ConcurrentModificationException的原因及其解决方案。包括使用Iterator安全删除元素、为遍历过程加锁以及利用ConcurrentHashMap替代HashMap的方法。

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

昨天遇到一个问题,就是在遍历Map的时候,报了一个异常:

java.util.ConcurrentModificationException
	at java.util.HashMap$HashIterator.nextNode(HashMap.java:1437)
	at java.util.HashMap$EntryIterator.next(HashMap.java:1471)
	at java.util.HashMap$EntryIterator.next(HashMap.java:1469)

发现原因如下:

Iterator做遍历的时候,HashMap被修改时会检查HashMap的size,size发生变化,抛出错误ConcurrentModificationException。

给出的解决方案如下:

1) 通过Iterator修改Hashtable

while(it.hasNext()) {
        Object ele = it.next();
        it.remove();
}

2) 根据实际程序,您自己手动给Iterator遍历的那段程序加锁,给修改HashMap的那段程序加锁。

3) 使用“ConcurrentHashMap”替换HashMap

ConcurrentHashMap会自己检查修改操作,对其加锁,也可针对插入操作。

import java.util.concurrent.*;

我采用的是第三种,代码如下:

Map<String, String> map = new ConcurrentHashMap<String, String>();			
map.putAll(param);
for (Map.Entry<String, String> entry : map.entrySet()) {
	String key = entry.getKey();
	map.remove(key);
}

其中param就是调用类传入的map,把它转成 ConcurrentHashMap,然后再进行循环操作。
 

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值