Class ObjectGraphIterator
- All Implemented Interfaces:
- Iterator
 This iterator can extract multiple objects from a complex tree-like object graph.
 The iteration starts from a single root object.
 It uses a Transformer to extract the iterators and elements.
 Its main benefit is that no intermediate List is created.
 
For example, consider an object graph:
                 |- Branch -- Leaf
                 |         \- Leaf
         |- Tree |         /- Leaf
         |       |- Branch -- Leaf
  Forest |                 \- Leaf
         |       |- Branch -- Leaf
         |       |         \- Leaf
         |- Tree |         /- Leaf
                 |- Branch -- Leaf
                 |- Branch -- Leaf
 The following Transformer, used in this class, will extract all
 the Leaf objects without creating a combined intermediate list:
 
 public Object transform(Object input) {
   if (input instanceof Forest) {
     return ((Forest) input).treeIterator();
   }
   if (input instanceof Tree) {
     return ((Tree) input).branchIterator();
   }
   if (input instanceof Branch) {
     return ((Branch) input).leafIterator();
   }
   if (input instanceof Leaf) {
     return input;
   }
   throw new ClassCastException();
 }
 Internally, iteration starts from the root object. When next is called, the transformer is called to examine the object. The transformer will return either an iterator or an object. If the object is an Iterator, the next element from that iterator is obtained and the process repeats. If the element is an object it is returned.
Under many circumstances, linking Iterators together in this manner is more efficient (and convenient) than using nested for loops to extract a list.
- Since:
- Commons Collections 3.1
- Version:
- $Revision: 647116 $ $Date: 2008-04-11 13:23:08 +0200 (Fri, 11 Apr 2008) $
- Author:
- Stephen Colebourne
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected IteratorThe current iteratorprotected ObjectThe current valueprotected booleanWhether there is another element in the iterationprotected IteratorThe last used iterator, needed for remove()protected ObjectThe root object in the treeprotected final ArrayStackThe stack of iteratorsprotected TransformerThe transformer to use
- 
Constructor SummaryConstructorsConstructorDescriptionObjectGraphIterator(Object root, Transformer transformer) Constructs an ObjectGraphIterator using a root object and transformer.ObjectGraphIterator(Iterator rootIterator) Constructs a ObjectGraphIterator that will handle an iterator of iterators.
- 
Method SummaryModifier and TypeMethodDescriptionprotected voidFinds the next object in the iteration given any start object.protected voidfindNextByIterator(Iterator iterator) Finds the next object in the iteration given an iterator.booleanhasNext()Checks whether there are any more elements in the iteration to obtain.next()Gets the next element of the iteration.voidremove()Removes from the underlying collection the last element returned.protected voidLoops around the iterators to find the next value to return.Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface java.util.IteratorforEachRemaining
- 
Field Details- 
stackThe stack of iterators
- 
rootThe root object in the tree
- 
transformerThe transformer to use
- 
hasNextprotected boolean hasNextWhether there is another element in the iteration
- 
currentIteratorThe current iterator
- 
currentValueThe current value
- 
lastUsedIteratorThe last used iterator, needed for remove()
 
- 
- 
Constructor Details- 
ObjectGraphIteratorConstructs an ObjectGraphIterator using a root object and transformer.The root object can be an iterator, in which case it will be immediately looped around. - Parameters:
- root- the root object, null will result in an empty iterator
- transformer- the transformer to use, null will use a no effect transformer
 
- 
ObjectGraphIteratorConstructs a ObjectGraphIterator that will handle an iterator of iterators.This constructor exists for convenience to emphasise that this class can be used to iterate over nested iterators. That is to say that the iterator passed in here contains other iterators, which may in turn contain further iterators. - Parameters:
- rootIterator- the root iterator, null will result in an empty iterator
 
 
- 
- 
Method Details- 
updateCurrentIteratorprotected void updateCurrentIterator()Loops around the iterators to find the next value to return.
- 
findNextFinds the next object in the iteration given any start object.- Parameters:
- value- the value to start from
 
- 
findNextByIteratorFinds the next object in the iteration given an iterator.- Parameters:
- iterator- the iterator to start from
 
- 
hasNextpublic boolean hasNext()Checks whether there are any more elements in the iteration to obtain.
- 
nextGets the next element of the iteration.- Specified by:
- nextin interface- Iterator
- Returns:
- the next element from the iteration
- Throws:
- NoSuchElementException- if all the Iterators are exhausted
 
- 
removepublic void remove()Removes from the underlying collection the last element returned.This method calls remove() on the underlying Iterator and it may throw an UnsupportedOperationException if the underlying Iterator does not support this method. - Specified by:
- removein interface- Iterator
- Throws:
- UnsupportedOperationException- if the remove operator is not supported by the underlying Iterator
- IllegalStateException- if the next method has not yet been called, or the remove method has already been called after the last call to the next method.
 
 
-