现在的位置: 首页 > 综合 > 正文

迭代模式(Iterator Pattern)

2014年05月16日 ⁄ 综合 ⁄ 共 1270字 ⁄ 字号 评论关闭

    在Java和.net编程环境下,迭代模式是非常普通的设计模式。这个设计模式能够以序列化的方式访问一个集合对象的元素,并且没有必要知道它内部的实现。迭代模式属于行为型模式之一,在使用中也是很常见的。

    在这个实例中,我们定义了接口Iterator和Container。具体的类NameRespository实现Container接口,它负责实现Iterator接口和使用它。UML图如下所示:


     接口Iterator.java

public interface Iterator {
   public boolean hasNext();
   public Object next();
}

    接口Container.java

public interface Container {
   public Iterator getIterator();
}

    具体的实现类NameRepository.java

public class NameRepository implements Container {
   public String names[] = {"Robert" , "John" ,"Julie" , "Lora"};
 
   @Override
   public Iterator getIterator() {
      return new NameIterator();
   }
 
   private class NameIterator implements Iterator {
 
      int index;
 
      @Override
      public boolean hasNext() {
         if(index < names.length){
            return true;
         }
         return false;
      }
 
      @Override
      public Object next() {
         if(this.hasNext()){
            return names[index++];
         }
         return null;
      }             
   }
}

 

测试类IteratorPatternDemo.java

public class IteratorPatternDemo {
          
   public static void main(String[] args) {
      NameRepository namesRepository = new NameRepository();
 
      for(Iterator iter = namesRepository.getIterator(); iter.hasNext();){
         String name = (String)iter.next();
         System.out.println("Name : " + name);
      }   
   }
}

输出结果:

Name : Robert
Name : John
Name : Julie
Name : Lora
【上篇】
【下篇】

抱歉!评论已关闭.