官术网_书友最值得收藏!

Implementation

The iterator pattern is based on two abstract classes or interfaces, which can be implemented by pairs of concrete classes. The class diagram is as follows:

The following classes are used in the iterator pattern:

  • Aggregate: The abstract class that should be implemented by all the classes and can be traversed by an iterator. This corresponds to the java.util.Collection interface.
  • Iterator: This is the iterator abstraction that defines the operations to traverse the aggregate object along with the one to return the object.
  • ConcreteAggregate: Concrete aggregates can implement internally different structures, but expose the concrete iterator, which deals with traversing the aggregates.
  • ConcreteIterator: This is the concrete iterator that deals with a specific concrete aggregate class. In practice, for each ConcreteAggregate, we have to implement a ConcreteIterator.

Using the iterators in Java is probably one of the things every programmer does in daily life. Let's see how we can implement an iterator. First of all, we should define a simple iterator interface:

public interface Iterator
{
public Object next();
public boolean hasNext();
}
We create the aggregate:
public interface Aggregate
{
public Iterator createIterator();
}

Then we implement a simple Aggregator, which maintains an array of String values:

public class StringArray implements Aggregate 
{ 
  private String values[]; 
  public StringArray(String[] values) 
{ this.values = values; } public Iterator createIterator() { return (Iterator) new StringArrayIterator(); } private class StringArrayIterator implements Iterator { private int position; public boolean hasNext() { return (position < values.length); } public String next() { if (this.hasNext()) return values[position++]; else return null; } } }

We nested the iterator class in the aggregate. This is the best option because the iterator needs access to the internal variables of the aggregator. We can see here how it looks:

String arr[]= {"a", "b", "c", "d"};
StringArray strarr = new StringArray(arr);
for (Iterator it = strarr.createIterator(); it.hasNext();)
System.out.println(it.next());
主站蜘蛛池模板: 璧山县| 德令哈市| 巍山| 府谷县| 建始县| 乌拉特中旗| 托克逊县| 内黄县| 江安县| 中宁县| 柏乡县| 桓台县| 渝中区| 镇巴县| 德江县| 澄江县| 九寨沟县| 通道| 山阴县| 陕西省| 安徽省| 临沂市| 玉门市| 建德市| 青田县| 兴隆县| 疏勒县| 玉溪市| 连江县| 泽州县| 玉树县| 内黄县| 集安市| 米泉市| 大厂| 富顺县| 寿阳县| 海口市| 缙云县| 玉溪市| 大丰市|