1.并发修改异常的原因是什么?
原因: 使用迭代器遍历集合元素时,又通过集合对象本身调用集合的方法,修改了集合的长度
解决方案:
使用迭代器遍历集合元素时,不能通过集合对象本身调用集合的方法,修改集合的长度
(1)使用Collection接口迭代器的方法修改长度: remove
(2)使用List接口特有迭代器List Iterator中的方法修改长度: remove,add
2.为什么使用迭代器遍历Collection集合时,使用集合对象的remove方法删除倒数第二个元素,不报并发修改异常?
如果想让其不抛出异常,一个办法是让iterator在调用hasNext()方法的时候返回false,这样就不会进到next()方法里了。这里cursor是指当前遍历时下一个元素的索引号。比如删除倒数第二个元素的时候,cursor指向最后一个元素的,而此时删掉了倒数第二个元素后,cursor和size()正好相等了,所以hasNext()返回false,遍历结束,这样就成功的删除了倒数第二个元素了。
本文探讨了并发修改异常产生的原因,即在使用迭代器遍历集合时通过集合对象直接修改集合长度。为避免此异常,建议使用迭代器自身提供的方法进行修改。同时,解释了为何在特定情况下,删除Collection集合的倒数第二个元素不会引发并发修改异常,这涉及到hasNext()方法的返回逻辑。
913





