structure
Class AbstractIterator<ELTTYPE>

java.lang.Object
  extended by structure.AbstractIterator<ELTTYPE>
All Implemented Interfaces:
java.util.Enumeration<ELTTYPE>, java.util.Iterator<ELTTYPE>
Direct Known Subclasses:
AbstractListIterator, ArrayIterator, DoublyLinkedListIterator

public abstract class AbstractIterator<ELTTYPE>
extends java.lang.Object
implements java.util.Enumeration<ELTTYPE>, java.util.Iterator<ELTTYPE>

Abstract base class for portable iterator and enumeration implementation.

A general purpose iterator that implements both java.util.Iterator and java.util.Enumeration. This class also implements the value() method, providing multiple accesses, and the reset() method, which allows the user to restart the traversal.

Typical usage:

     Vector v = new Vector;
     String s = "target";
     ...
     Iterator t = v.iterator()();
     // print members of vector that are greater than s
     for (t.reset(); t.hasNext(); t.next())
     {
         if (s.compareTo(t.value()) < 0)
               System.out.println(t.value());
     }
 

Users of Java's Enumeration or Iterator may treat the AbstractIterator as an Enumeration or Iterator, respectively, without ill effect.

Appropriate care should be taken to make sure that the underlying data structure is not modified while the traversal is active. Some extensions of this class may choose to provide methods that modify the structure --- the remove method of iterator is one such possibility. Care should be taken to make sure that such modifications are carefully synchronized, or limited to one active traversal.

See Also:
Iterator, Enumeration

Constructor Summary
AbstractIterator()
          Default constructor (for base class invocation).
 
Method Summary
abstract  ELTTYPE get()
          Returns the value currently being considered by the AbstractIterator.
 boolean hasMoreElements()
          An Enumeration method that is equivalent to hasNext().
abstract  boolean hasNext()
          Returns true if the iterator has more elements to visit.
abstract  ELTTYPE next()
          Moves, bumps, or "increments" the iterator along the traversal; returns the next value considered.
 ELTTYPE nextElement()
          An Enumeration method that is equivalent to next().
 void remove()
          If implemented, removes the currently visited value from the structure.
abstract  void reset()
          Reset iterator to the beginning of the structure.
 ELTTYPE value()
          Deprecated. This method was deprecated in version 2 of the structure package. Use the get method.
 
Methods inherited from class java.lang.Object
equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Constructor Detail

AbstractIterator

public AbstractIterator()
Default constructor (for base class invocation). Does nothing. Remind Sun (jdk-comments@java.sun.com) that automatically implemented default constructors are a silly thing.

Post:
does nothing
Method Detail

reset

public abstract void reset()
Reset iterator to the beginning of the structure. This method is not required of Iterator or Enumeration implementation, but some traversals may allow efficient multi-pass implementations with little overhead. The user is encouraged to implement this method.

Pre:
iterator may be initialized or even amid-traversal
Post:
reset iterator to the beginning of the structure

hasNext

public abstract boolean hasNext()
Returns true if the iterator has more elements to visit. The method hasMoreElements is an Enumeration-required call to this method. The user should override only this method.

Specified by:
hasNext in interface java.util.Iterator<ELTTYPE>
Returns:
true iff the iterator has more elements to visit
See Also:
hasMoreElements()
Post:
true iff the iterator has more elements to visit

get

public abstract ELTTYPE get()
Returns the value currently being considered by the AbstractIterator. This method is required by neither Iterator nor Enumeration. This method should be implemented, however, to provide better support for for-loops.

Returns:
the next value to be considered in iterator
Pre:
there are more elements to be considered; hasNext()
Post:
returns current value; ie. value next() will return

value

public final ELTTYPE value()
Deprecated. This method was deprecated in version 2 of the structure package. Use the get method.

Returns the value currently being considered by the AbstractIterator. This method is required by neither Iterator nor Enumeration. This method should be implemented, however, to provide better support for for-loops.

Returns:
the next value to be considered in iterator
Pre:
there are more elements to be considered; hasNext()
Post:
returns the current value; the value next() will return

next

public abstract ELTTYPE next()
Moves, bumps, or "increments" the iterator along the traversal; returns the next value considered. This method should only be called if the iterator has a next value. To get a value from an iterator multiple times, use the value method.

This method is preferred over the nextElement method.

Specified by:
next in interface java.util.Iterator<ELTTYPE>
Returns:
the current value
See Also:
hasMoreElements(), value()
Pre:
hasNext()
Post:
returns current value, and then increments iterator

remove

public void remove()
If implemented, removes the currently visited value from the structure. remove should not be called unless it is overridden.

Specified by:
remove in interface java.util.Iterator<ELTTYPE>
Pre:
hasNext() is true and get() has not been called
Post:
the value has been removed from the structure

hasMoreElements

public final boolean hasMoreElements()
An Enumeration method that is equivalent to hasNext(). Extensions to this class should provide a hasNext method.

Specified by:
hasMoreElements in interface java.util.Enumeration<ELTTYPE>
Returns:
returns true iff there are more elements
Post:
returns true iff there are more elements

nextElement

public final ELTTYPE nextElement()
An Enumeration method that is equivalent to next(). Extensions to this class should provide a next method.

Specified by:
nextElement in interface java.util.Enumeration<ELTTYPE>
Returns:
the current value before iterator is incremented
Pre:
hasNext()
Post:
returns the current value and "increments" the iterator