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

点击打开转载处链接
迭代器模式:

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

那么可以换下一个频道,而不需要知道它是几频道。

如图:


[java]  view plain copy print ?
  1. package design.iterator;  
  2.   
  3.   
  4. /** 
  5.  * 文件名称:design.singleton.Singleton.java 
  6.  * 创建人:Fei Wong 
  7.  * 创建时间: 2012-06-20 
  8.  * 电子邮箱:feiwong8@126.com 
  9.  * 说明:迭代模式,创建迭代类 
  10.  * */  
  11. public interface Iterator<T> {  
  12.     public T first();   
  13.     public T next();  
  14.     public boolean isDone() ;   
  15.     public T currentItem();    
  16.     public T add(T t) ;  
  17. }  
  18.   
  19. package design.iterator;  
  20.   
  21. import java.util.List;  
  22. /** 
  23.  * 文件名称:design.singleton.Singleton.java 
  24.  * 创建人:Fei Wong 
  25.  * 创建时间: 2012-06-20 
  26.  * 电子邮箱:feiwong8@126.com 
  27.  * 说明:实现迭代接口 
  28.  * */  
  29. public class ArrayIterator<T> implements Iterator<T> {  
  30.     private List<T> list ;  
  31.       
  32.     private int index = 0 ;   
  33.       
  34.     public ArrayIterator(List<T> list){  
  35.         this.list = list ;   
  36.         index = 0 ;   
  37.     }  
  38.       
  39.     @Override  
  40.     public T currentItem() {  
  41.         return null;  
  42.     }  
  43.   
  44.     @Override  
  45.     public T first() {  
  46.         index = 0 ;   
  47.         return list.get( 0 ) ;   
  48.     }  
  49.   
  50.     @Override  
  51.     public boolean isDone() {  
  52.         return list.size() > index ;   
  53.     }  
  54.       
  55.     @Override  
  56.     public T next() {  
  57.         return list.get( index++ ) ;     
  58.     }  
  59.   
  60.     @Override  
  61.     public T add(T t) {  
  62.         list.add( t ) ;   
  63.         return t ;  
  64.     }  
  65. }  
  66.   
  67. package design.iterator;  
  68.   
  69. import java.util.Vector;  
  70. /** 
  71.  * 文件名称:design.singleton.Singleton.java 
  72.  * 创建人:Fei Wong 
  73.  * 创建时间: 2012-06-20  
  74.  * 电子邮箱:feiwong8@126.com 
  75.  * 说明:调用迭代接口 
  76.  * */  
  77. public class Main {  
  78.     public static void main(String[] args) {  
  79.         Vector<Integer> vector = new Vector<Integer>() ;  
  80.         Iterator<Integer>iterator = new ArrayIterator<Integer>( vector ) ;  
  81.         iterator.add( 1 ) ;   
  82.         iterator.add( 2 ) ;   
  83.         iterator.add( 3) ;   
  84.         iterator.add( 4) ;   
  85.         iterator.add( 5 ) ;   
  86.         iterator.add( 6 ) ;   
  87.         while (iterator.isDone()) {  
  88.             System.out.println( iterator.next() );  
  89.         }  
  90.     }  
  91. }  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值