Package com.google.common.collect
Class AbstractSequentialIterator<T>
- java.lang.Object
-
- com.google.common.collect.UnmodifiableIterator<T>
-
- com.google.common.collect.AbstractSequentialIterator<T>
-
- All Implemented Interfaces:
Iterator<T>
@GwtCompatible public abstract class AbstractSequentialIterator<T> extends UnmodifiableIterator<T>
This class provides a skeletal implementation of theIterator
interface for sequences whose next element can always be derived from the previous element. Null elements are not supported, nor is theUnmodifiableIterator.remove()
method.Example:
Iterator<Integer> powersOfTwo = new AbstractSequentialIterator<Integer>(1) { protected Integer computeNext(Integer previous) { return (previous == 1 << 30) ? null : previous * 2; } };
- Since:
- 12.0 (in Guava as
AbstractLinkedIterator
since 8.0) - Author:
- Chris Povirk
-
-
Constructor Summary
Constructors Modifier Constructor Description protected
AbstractSequentialIterator(@Nullable T firstOrNull)
Creates a new iterator with the given first element, or, iffirstOrNull
is null, creates a new empty iterator.
-
Method Summary
All Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description protected abstract @Nullable T
computeNext(T previous)
Returns the element that followsprevious
, or returnsnull
if no elements remain.boolean
hasNext()
Returnstrue
if the iteration has more elements.T
next()
Returns the next element in the iteration.-
Methods inherited from class com.google.common.collect.UnmodifiableIterator
remove
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
-
Methods inherited from interface java.util.Iterator
forEachRemaining
-
-
-
-
Constructor Detail
-
AbstractSequentialIterator
protected AbstractSequentialIterator(@Nullable T firstOrNull)
Creates a new iterator with the given first element, or, iffirstOrNull
is null, creates a new empty iterator.
-
-
Method Detail
-
computeNext
protected abstract @Nullable T computeNext(T previous)
Returns the element that followsprevious
, or returnsnull
if no elements remain. This method is invoked during each call tonext()
in order to compute the result of a future call tonext()
.
-
hasNext
public final boolean hasNext()
Description copied from interface:java.util.Iterator
Returnstrue
if the iteration has more elements. (In other words, returnstrue
ifIterator.next()
would return an element rather than throwing an exception.)- Returns:
true
if the iteration has more elements
-
next
public final T next()
Description copied from interface:java.util.Iterator
Returns the next element in the iteration.- Returns:
- the next element in the iteration
-
-