Package com.google.common.collect
Class TreeTraverser.PostOrderIterator
- java.lang.Object
-
- com.google.common.collect.UnmodifiableIterator<T>
-
- com.google.common.collect.AbstractIterator<T>
-
- com.google.common.collect.TreeTraverser.PostOrderIterator
-
- All Implemented Interfaces:
java.util.Iterator<T>
- Enclosing class:
- TreeTraverser<T>
private final class TreeTraverser.PostOrderIterator extends AbstractIterator<T>
-
-
Field Summary
Fields Modifier and Type Field Description private java.util.ArrayDeque<TreeTraverser.PostOrderNode<T>>stack
-
Constructor Summary
Constructors Constructor Description PostOrderIterator(T root)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description protected TcomputeNext()Returns the next element.private TreeTraverser.PostOrderNode<T>expand(T t)-
Methods inherited from class com.google.common.collect.AbstractIterator
endOfData, hasNext, next, peek
-
Methods inherited from class com.google.common.collect.UnmodifiableIterator
remove
-
-
-
-
Field Detail
-
stack
private final java.util.ArrayDeque<TreeTraverser.PostOrderNode<T>> stack
-
-
Constructor Detail
-
PostOrderIterator
PostOrderIterator(T root)
-
-
Method Detail
-
computeNext
protected T computeNext()
Description copied from class:AbstractIteratorReturns the next element. Note: the implementation must callAbstractIterator.endOfData()when there are no elements left in the iteration. Failure to do so could result in an infinite loop.The initial invocation of
AbstractIterator.hasNext()orAbstractIterator.next()calls this method, as does the first invocation ofhasNextornextfollowing each successful call tonext. Once the implementation either invokesendOfDataor throws an exception,computeNextis guaranteed to never be called again.If this method throws an exception, it will propagate outward to the
hasNextornextinvocation that invoked this method. Any further attempts to use the iterator will result in anIllegalStateException.The implementation of this method may not invoke the
hasNext,next, orAbstractIterator.peek()methods on this instance; if it does, anIllegalStateExceptionwill result.- Specified by:
computeNextin classAbstractIterator<T>- Returns:
- the next element if there was one. If
endOfDatawas called during execution, the return value will be ignored.
-
expand
private TreeTraverser.PostOrderNode<T> expand(T t)
-
-