为什么我在迭代期间从 ArrayList 中删除元素时没有得到 ConcurrentModificationException



我使用以下代码循环遍历数组列表,然后从数组列表中删除一个元素。

在这里,我期待ConcurrentModificationException。但没有得到那个例外。特别是当您检查第 (n-1( 个元素的条件时。请帮助我。下面是我的代码。

ArrayList<Integer> arrayList = new ArrayList<Integer>();
for (int i = 1; i <= 10; i++) {
arrayList.add(5 * i);
}
System.out.println(arrayList);
Iterator<Integer> iterator = arrayList.iterator();
while (iterator.hasNext()) {
Integer temp = iterator.next();
if (temp == 45) {
/**
* temp == 40 (then i'm getting *ConcurrentModificationException) why not i'm
* getting ConcurrentModificationException if (temp == 45)
*/
arrayList.remove(1);
}
}
System.out.println(arrayList);

提前致谢

该实现会尽最大努力检测并发修改,但在某些情况下它无法这样做。

Iterator的实现返回ArrayListIterator检查next()remove()中的并发修改,但不返回hasNext()的并发修改,其逻辑是:

public boolean hasNext() {
return cursor != size;
}

由于您在Iterator的光标位于最后一个元素之前的元素上时删除了元素,因此删除会导致hasNext()返回false(因为删除后size等于cursor(,这将结束循环而不会引发异常。

相关内容

  • 没有找到相关文章

最新更新