今天在高级for循环中用了一下remove发现报错,写了个demo测试看:1
2
3
4
5
6
7 List<String> a = new ArrayList<String>();
a.add("1");
a.add("2");
for (String temp : a) {
if("1".equals(temp)){
a.remove(temp);
} }
此时代码是没有问题的,运行正常;但是把”1”.equals(temp)换成”2”.equals(temp)之后,问题就出来了!
1 | Exception in thread "main" java.util.ConcurrentModificationException |
报了这么一堆异常。
自己想了想画了个图:
看图就明白了,该list每当删除一个元素时,集合的size方法的值都会减小1,这将直接导致集合中元素的索引重新排序,进一步说,就是剩余所有元素的索引值都减1,正如上图所示,而for循环语句的局部变量i仍然在递增,这将导致删除操作发生跳跃。从而导致上述代码还有删除的问题。
所以不要在 foreach 循环里进行元素的 remove/add 操作。remove 元素请使用 Iterator 方式,如果并发操作,需要对 Iterator 对象加锁。如下:
1 | Iterator<String> it = a.iterator(); (it.hasNext()){ |