E - the type of elements returned by this iteratorpublic interface Iterator<E>
Iterator takes the place of
 Enumeration in the Java Collections Framework.  Iterators
 differ from enumerations in two ways:
 This interface is a member of the Java Collections Framework.
Collection, 
ListIterator, 
Iterable| Modifier and Type | Method | Description | 
|---|---|---|
| default void | forEachRemaining(Consumer<? super E> action) | Performs the given action for each remaining element until all elements
 have been processed or the action throws an exception. | 
| boolean | hasNext() | Returns  trueif the iteration has more elements. | 
| E | next() | Returns the next element in the iteration. | 
| default void | remove() | Removes from the underlying collection the last element returned
 by this iterator (optional operation). | 
boolean hasNext()
true if the iteration has more elements.
 (In other words, returns true if next() would
 return an element rather than throwing an exception.)true if the iteration has more elementsE next()
NoSuchElementException - if the iteration has no more elementsdefault void remove()
next().  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.UnsupportedOperationException and performs no other action.UnsupportedOperationException - if the remove
         operation is not supported by this iteratorIllegalStateException - if the next method has not
         yet been called, or the remove method has already
         been called after the last call to the next
         methoddefault void forEachRemaining(Consumer<? super E> action)
The default implementation behaves as if:
     while (hasNext())
         action.accept(next());
 action - The action to be performed for each elementNullPointerException - if the specified action is null Submit a bug or feature 
For further API reference and developer documentation, see Java SE Documentation. That documentation contains more detailed, developer-targeted descriptions, with conceptual overviews, definitions of terms, workarounds, and working code examples.
 Copyright © 1993, 2025, Oracle and/or its affiliates.  All rights reserved. Use is subject to license terms. Also see the documentation redistribution policy.