8168745: Iterator.forEachRemaining vs. Iterator.remove

Reviewed-by: martin, smarks
This commit is contained in:
Paul Sandoz 2016-11-30 17:15:58 -08:00
parent 118c620fd7
commit 7e58564540
2 changed files with 22 additions and 7 deletions

View File

@ -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:

View File

@ -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: