8168745: Iterator.forEachRemaining vs. Iterator.remove
Reviewed-by: martin, smarks
This commit is contained in:
parent
118c620fd7
commit
7e58564540
@ -53,10 +53,13 @@ public interface Iterable<T> {
|
|||||||
/**
|
/**
|
||||||
* Performs the given action for each element of the {@code Iterable}
|
* Performs the given action for each element of the {@code Iterable}
|
||||||
* until all elements have been processed or the action throws an
|
* until all elements have been processed or the action throws an
|
||||||
* exception. Unless otherwise specified by the implementing class,
|
* exception. Actions are performed in the order of iteration, if that
|
||||||
* actions are performed in the order of iteration (if an iteration order
|
* order is specified. Exceptions thrown by the action are relayed to the
|
||||||
* is specified). Exceptions thrown by the action are relayed to the
|
|
||||||
* caller.
|
* caller.
|
||||||
|
* <p>
|
||||||
|
* The behavior of this method is unspecified if the action performs
|
||||||
|
* side-effects that modify the underlying source of elements, unless an
|
||||||
|
* overriding class has specified a concurrent modification policy.
|
||||||
*
|
*
|
||||||
* @implSpec
|
* @implSpec
|
||||||
* <p>The default implementation behaves as if:
|
* <p>The default implementation behaves as if:
|
||||||
|
@ -76,10 +76,15 @@ public interface Iterator<E> {
|
|||||||
/**
|
/**
|
||||||
* Removes from the underlying collection the last element returned
|
* Removes from the underlying collection the last element returned
|
||||||
* by this iterator (optional operation). This method can be called
|
* by this iterator (optional operation). This method can be called
|
||||||
* only once per call to {@link #next}. The behavior of an iterator
|
* only once per call to {@link #next}.
|
||||||
* is unspecified if the underlying collection is modified while the
|
* <p>
|
||||||
* iteration is in progress in any way other than by calling this
|
* The behavior of an iterator is unspecified if the underlying collection
|
||||||
* method.
|
* is modified while the iteration is in progress in any way other than by
|
||||||
|
* calling this method, unless an overriding class has specified a
|
||||||
|
* concurrent modification policy.
|
||||||
|
* <p>
|
||||||
|
* The behavior of an iterator is unspecified if this method is called
|
||||||
|
* after a call to the {@link #forEachRemaining forEachRemaining} method.
|
||||||
*
|
*
|
||||||
* @implSpec
|
* @implSpec
|
||||||
* The default implementation throws an instance of
|
* The default implementation throws an instance of
|
||||||
@ -102,6 +107,13 @@ public interface Iterator<E> {
|
|||||||
* have been processed or the action throws an exception. Actions are
|
* have been processed or the action throws an exception. Actions are
|
||||||
* performed in the order of iteration, if that order is specified.
|
* performed in the order of iteration, if that order is specified.
|
||||||
* Exceptions thrown by the action are relayed to the caller.
|
* Exceptions thrown by the action are relayed to the caller.
|
||||||
|
* <p>
|
||||||
|
* The behavior of an iterator is unspecified if the action modifies the
|
||||||
|
* collection in any way (even by calling the {@link #remove remove} method),
|
||||||
|
* unless an overriding class has specified a concurrent modification policy.
|
||||||
|
* <p>
|
||||||
|
* Subsequent behavior of an iterator is unspecified if the action throws an
|
||||||
|
* exception.
|
||||||
*
|
*
|
||||||
* @implSpec
|
* @implSpec
|
||||||
* <p>The default implementation behaves as if:
|
* <p>The default implementation behaves as if:
|
||||||
|
Loading…
Reference in New Issue
Block a user