这个事情本身比较简单,但是在java中想直接实现却有些棘手。如果直接用for each的方式,删除其中的元素的话会报出ConcurrentModificationException异常。原因很简单,就是你改变了list,那么之前生成的迭代器就不能再继续工作了。
上面这个问题碰到很多次了,之前总是用比较猥琐的办法绕过去。比如只删除一个元素的话,找到记录下来再删除;或者干脆新建一个数组,把找到的东西移动过去。今天突然上网查了一下,发现了个很好的帖子,从正面解决了这个问题。
解决思路:利用for循环,将数组反向遍历。for循环可以解决在循环过程中改变列表不能继续的问题,因为用的是get方法取元素。反向便利解决了如果删除一个元素,后面的元素会向前移动的问题。这样一来就和普通的循环一样操作就可以了。
示例:
for (int i = list.size(); i >= 0; i--) {
if ((i + 1) % 2 == 0) {
list.remove(i);
}
}
感想:不是所有问题都是技术问题,很多时候一个好的思路就能巧妙的解决问题。
本文转自passover 51CTO博客,原文链接:http://blog.51cto.com/passover/691932,如需转载请自行联系原作者