Why iterator.forEachRemaining doesnt remove element in the Consumer lambda?

江枫思渺然 提交于 2019-11-30 02:58:42

问题


Lets have a look at this example:

public class ListIteratorTest {
    public static void main(String[] args) {
        List<String> list = new ArrayList<>();
        list.add("element1");
        list.add("element2");
        list.add("element3");
        list.add("element4");

        ListIterator<String> iterator = list.listIterator();
    }
}

And now, this works fine:

    // prints elements out, and then appropriately removes one after another
    while (iterator.hasNext()){
        System.out.println(iterator.next());
        iterator.remove();
    }

while this throws an IllegalStateException:

        // throws IllegalStateException, why?
        iterator.forEachRemaining(n -> {
            System.out.println(n);
            iterator.remove();
        });

My question is short: why?


回答1:


Updated thanks to @studro. See his comment below.

The API documentation states:

The behavior of an iterator is unspecified if the underlying collection is modified while the iteration is in progress in any way other than by calling this method.

It seems like the "unspecified behavior" part also applies during this internal iteration.

Granted, the documentation for forEachRemaining states that the behavior is equivalent to

while (hasNext())
    action.accept(next());

and if action::accept did in fact call iterator.remove() the above snippet should not throw any exception (if remove is a supported operation). This might be a documentation bug.



来源:https://stackoverflow.com/questions/29210510/why-iterator-foreachremaining-doesnt-remove-element-in-the-consumer-lambda

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!