微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

遍历聚合对象中的元素——迭代器模式四

遍历聚合对象中的元素——迭代器模式(四)


4 使用内部类实现迭代器

       在迭代器模式结构图中,我们可以看到具体迭代器类和具体聚合类之间存在双重关系,其中一个关系为关联关系,在具体迭代器中需要维持一个对具体聚合对象的引用,该关联关系的目的是访问存储在聚合对象中的数据,以便迭代器能够对这些数据进行遍历操作。

       除了使用关联关系外,为了能够让迭代器可以访问到聚合对象中的数据,我们还可以将迭代器类设计为聚合类的内部类JDK中的迭代器类就是通过这种方法来实现的,如下AbstractList代码片段所示:

[java]  view plain copy
  1. package java.util;  
  2. ……  
  3. public abstract class AbstractList<E> extends AbstractCollection<E> implements List<E> {  
  4.     ......  
  5.     private class Itr implements Iterator<E> {  
  6.         int cursor = 0;  
  7.         ......  
  8. }  
  9. ……  
  10. }  

       我们可以通过类似的方法来设计第3节中的ProductList类,将ProductIterator类作为ProductList类的内部类,代码如下所示:

copy
    //商品数据类:具体聚合类  
  1. class ProductList extends AbstractObjectList {  
  2. public ProductList(List products) {  
  3. super(products);  
  4.     }  
  5.       
  6. public AbstractIterator createIterator() {  
  7. return new ProductIterator();  
  8.     //商品迭代器:具体迭代器,内部类实现  
  9.     class ProductIterator implements AbstractIterator {  
  10.         int cursor1;  
  11. int cursor2;  
  12.           
  13. public ProductIterator() {  
  14.             cursor1 = 0;  
  15.             cursor2 = objects.size() -1;  
  16.         }  
  17.           
  18. void next() {  
  19.             if(cursor1 < objects.size()) {  
  20.                 cursor1++;  
  21.             }  
  22. boolean isLast() {  
  23. return (cursor1 == objects.size());  
  24. void prevIoUs() {  
  25. if(cursor2 > -1) {  
  26.                 cursor2--;  
  27. boolean isFirst() {  
  28. return (cursor2 == -1);  
  29. public Object getNextItem() {  
  30. return objects.get(cursor1);  
  31.         }   
  32.               
  33. public Object getPrevIoUsItem() {  
  34. return objects.get(cursor2);  
  35.         }     
  36.     }  
  37. }  

       无论使用哪种实现机制,客户端代码都是一样的,也就是说客户端无须关心具体迭代器对象的创建细节,只需通过调用工厂方法createIterator()即可得到一个可用的迭代器对象,这也是使用工厂方法模式的好处,通过工厂来封装对象的创建过程,简化了客户端的调用

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐