当前位置:编程学习 > JAVA >>

JAVA设计模式六--Iterator(迭代器模式)

迭代器模式:
在软件构建过程中,集合对象内部结构常常变化各异。但对于这些集合对象,我们希望在不暴露其内部结构的同时,
可以让外部客户代码透明地访问其中包含的元素;同时这种“透明遍历” 也为“同一种算法在多种集合对象上进行操作”提供了可能。
使用面向对象技术将这种遍历机制抽象为“迭代器对象”为“应对变化中的集合对象”提供了一种优雅的方法。
适用性:
1.访问一个聚合对象的内容而无需暴露它的内部表示。
2.支持对聚合对象的多种遍历。
3.为遍历不同的聚合结构提供一个统一的接口(即, 支持多态迭代)。
生活中的例子:
迭代器提供一种方法顺序访问一个集合对象中各个元素,而又不需要暴露该对象的内部表 示。在早期的电视机中,
一个拨盘用来改变频道。当改变频道时,需要手工转动拨盘移过每一个 频道,而不论这个频道是否有信号。
现在的电视机,使用[后一个]和[前一个]按钮。当按下[后 一个]按钮时,将切换到下一个预置的频道。
想象一下在陌生的城市中的旅店中看电视。当改变 频道时,重要的不是几频道,而是节目内容。如果对一个频道的节目不感兴趣,
那么可以换下一个频道,而不需要知道它是几频道。
如图:
 

[java]
package design.iterator; 
 
 
/**
 * 文件名称:design.singleton.Singleton.java
 * 创建人:Fei Wong
 * 创建时间: 2012-06-20
 * 电子邮箱:www.zzzyk.com
 * 说明:迭代模式,创建迭代类
 * */ 
public interface Iterator<T> { 
    public T first();  
    public T next(); 
    public boolean isDone() ;  
    public T currentItem();   
    public T add(T t) ; 

 
package design.iterator; 
 
import java.util.List; 
/**
 * 文件名称:design.singleton.Singleton.java
 * 创建人:Fei Wong
 * 创建时间: 2012-06-20
 * 电子邮箱:www.zzzyk.com
 * 说明:实现迭代接口
 * */ 
public class ArrayIterator<T> implements Iterator<T> { 
    private List<T> list ; 
     
    private int index = 0 ;  
     
    public ArrayIterator(List<T> list){ 
        this.list = list ;  
        index = 0 ;  
    } 
     
    @Override 
    public T currentItem() { 
        return null; 
    } 
 
    @Override 
    public T first() { 
        index = 0 ;  
        return list.get( 0 ) ;  
    } 
 
    @Override 
    public boolean isDone() { 
        return list.size() > index ;  
    } 
     
    @Override 
    public T next() { 
        return list.get( index++ ) ;    
    } 
 
    @Override 
    public T add(T t) { 
        list.add( t ) ;  
        return t ; 
    } 

 
package design.iterator; 
 
import java.util.Vector; 
/**
 * 文件名称:design.singleton.Singleton.java
 * 创建人:Fei Wong
 * 创建时间: 2012-06-20 
 * 电子邮箱:www.zzzyk.com
 * 说明:调用迭代接口
 * */ 
public class Main { 
    public static void main(String[] args) { 
        Vector<Integer> vector = new Vector<Integer>() ; 
        Iterator<Integer>iterator = new ArrayIterator<Integer>( vector ) ; 
        iterator.add( 1 ) ;  
        iterator.add( 2 ) ;  
        iterator.add( 3) ;  
        iterator.add( 4) ;  
        iterator.add( 5 ) ;  
        iterator.add( 6 ) ;  
        while (iterator.isDone()) { 
            System.out.println( iterator.next() ); 
        } 
    } 

作者:hfmbook

补充:软件开发 , Java ,
CopyRight © 2012 站长网 编程知识问答 www.zzzyk.com All Rights Reserved
部份技术文章来自网络,