zoukankan      html  css  js  c++  java
  • 迭代器模式

    模式介绍

    迭代器模式(Iterator Pattern)是Java编程环境中非常常用的设计模式。这种模式用于顺序访问集合对象的元素,不需要知道集合对象的底层表示。迭代器模式属于行为型模式。

    模式优点

    1、提供一种方法顺序访问一个聚合对象中各个元素, 而又无须暴露该对象的内部表示。
    2、它支持以不同的方式遍历一个聚合对象。
    3、在迭代器模式中,增加新的聚合类和迭代器类都很方便,无须修改原有代码。

    模式缺点

    1、迭代器模式将存储数据和遍历数据的职责分离,增加新的聚合类需要对应增加新的迭代器类,这在一定程度上增加了系统的复杂性。

    使用场景

    1、访问一个聚合对象的内容而无须暴露它的内部表示。
    2、需要为聚合对象提供多种遍历方式。
    3、为遍历不同的聚合结构提供一个统一的接口。

    系统建模

    1、创建一个迭代器方法的Iterator接口和一个返回迭代器的Container接口。
    2、实现了Container接口的实体类将负责实现Iterator接口。

    系统实现

    /**
     * 迭代器接口
     */
    public interface Iterator {
       public boolean hasNext();
       public Object next();
    }
    
    /**
     * 聚合接口
     */
    public interface Container {
       public Iterator getIterator();
    }
    
    /**
     * 聚合对象
     */
    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;
          }     
       }
    }
    
    /**
     * 客户端
     */
    public class Client{
       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
    
  • 相关阅读:
    基于redission的分布式锁
    kafka在Windows环境下启动
    Synchronized优化总结
    mysql死锁总结
    索引是建立得越多越好吗?
    show processlist 详解
    RocketMQ高可用机制同步刷盘、异步刷盘和同步复制、异步复制
    Redlock红锁总结
    C#2.0泛型
    《解剖PetShop》系列之四:PetShop之ASP.NET缓存 (转)
  • 原文地址:https://www.cnblogs.com/feiqiangsheng/p/12233514.html
Copyright © 2011-2022 走看看