设计模式——迭代器模式

迭代器模式(Iterator Pattern):
1.又称为游标(Cursor)模式,是行为型设计模式之一;
2.源于对容器的访问,把遍历方法封装到容器中。
3.提供一种方法顺序访问一个容器对象中的各个元素,而又不需要暴露该对象的内部表示。

使用场景:遍历一个容器对象时,例如,乘火车排队检票,对所有乘客进行遍历。

票务系统:相当于一个容器集合Aggregate
车票:遍历对象Object
检票口:迭代器Iterator

迭代器模式.jpg

代码示例:

/**
 * @author apple
 * 
 * 容器接口
 * 
 * 添加/删除元素
 * 
 * 获取容器迭代器
 *
 */
public interface Aggregate<T> {
    void addObject(T object);
    void deleteObject(T object);
    public Iterator<T> iterator();
}

/**
 * @author apple
 * 
 * 迭代器接口
 *
 */
public interface Iterator<T> {
    // 判断是否有下一个元素
    boolean hasNext();
    
    T first();
    
    // 返回当前位置的元素并将位置移至下一位
    T next();
}


/**
 * 
 * @author apple
 *
 * @param <T>
 * 
 * 具体集合类
 * 
 */

import java.util.ArrayList;
import java.util.List;

public class ConcreteAggregate<T>  implements Aggregate<T> {

    private List<T> list=new ArrayList<T>();
    
    @Override
    public void addObject(T object) {
        // TODO Auto-generated method stub
        list.add(object);
    }

    @Override
    public void deleteObject(T object) {
        // TODO Auto-generated method stub
        list.remove(object);
    }

    @Override
    public Iterator<T> iterator() {
        // TODO Auto-generated method stub
        return  new ConcreteIterator<T>(list);
        
    }

}

import java.util.List;

/**
 * 
 * @author apple
 *
 * @param <T>
 * 
 * 具体迭代器
 */

public class ConcreteIterator<T> implements Iterator<T> {
    
    private List<T> list = null;
    
    private int index = -1; 
    
    
    public ConcreteIterator(List<T> list) {
        super();
        this.list = list;
    }

    @Override
    public boolean hasNext() {
        // TODO Auto-generated method stub
        if (list.size() -1 > index) {
            return true;
        } else {
            return false;   
        }
    }

    @Override
    public T first() {
        // TODO Auto-generated method stub
        index = 0;
        T ticket = list.get(index); 
        return ticket;
    }

    @Override
    public T next() {
        // TODO Auto-generated method stub
        T ticket  = null;
        if (this.hasNext()) {
            ticket = list.get(++index);
        }
        return ticket;
    }

}

/**
 * @author apple
 * 
 * 票
 *
 */
public class Ticket {
    // 火车班次
    String trainNo;
    
    String name;

    public Ticket(String trainNo, String name) {
        super();
        this.trainNo = trainNo;
        this.name = name;
    }

    @Override
    public String toString() {
        return "Ticket [trainNo=" + trainNo + ", name=" + name + "]";
    }
}

/**
 * 
 * @author apple
 * 
 * 测试类
 *
 */
public class Client {

    public static void main(String[] args) {
        // TODO Auto-generated method stub
        
        Aggregate ag=new ConcreteAggregate();
        ag.addObject(new Ticket("108次", "张"));
        ag.addObject(new Ticket("108次", "李"));
        ag.addObject(new Ticket("108次", "王"));
        ag.addObject(new Ticket("107次", "王"));
        ag.addObject(new Ticket("108次", "棒槌"));
    
        Iterator iterator = ag.iterator();
        // 遍历 火车票
        while(iterator.hasNext()) {
             Ticket ob = (Ticket) iterator.next(); 
             System.out.println(ob.toString()+"\t"); 
        }
//      Ticket ob = (Ticket) iterator.first();
//        System.out.println("\nFirst:"+ob.toString());
    }

}

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 目录 本文的结构如下: 引言 什么是迭代器模式 模式的结构 典型代码 代码示例 优点和缺点 适用环境 模式应用 一...
    w1992wishes阅读 542评论 0 1
  • 前言 Android的设计模式系列文章介绍,欢迎关注,持续更新中: Android的设计模式-设计模式的六大原则一...
    四月葡萄阅读 3,708评论 0 4
  • 在阎宏博士的《JAVA与模式》一书中开头是这样描述迭代子(Iterator)模式的:迭代子模式又叫游标(Curso...
    Ant_way阅读 434评论 0 0
  • 定义 提供一种方法访问一个容器对象中各个元素,而又不需暴露该对象的内部细节。 介绍 迭代器模式属于行为型模式。 迭...
    敏捷Studio阅读 216评论 0 0
  • 认识你2年多了,也差不多喜欢你2年了,但是慢慢的我累了,你的性格我承受不起。不是我不爱你了,我累了!
    我累了__阅读 204评论 0 0