设计模式-iterator迭代模式

来源:互联网 发布:m400数据采集管理软件 编辑:程序博客网 时间:2024/05/17 15:39

问题起源

想找一些关于迭代器next()和hasNext()方法的内容,最后都归宗到迭代器以及设计模式中的迭代器模式。现在记录一下,有空写一篇学习心得。

一、什么是迭代模式

Iterator模式也叫迭代模式,是行为模式之一,它把对容器中包含的内部对象的访问委让给外部类,使用Iterator按顺序进行遍历访问的设计模式。

二、不使用迭代模式的应用

在应用Iterator模式之前,首先应该明白Iterator模式用来解决什么问题。或者说,如果不使用Iterator模式,会存在什么问题。
  1. 由容器自己实现顺序遍历。直接在容器类里直接添加顺序遍历方法
  2. 让调用者自己实现遍历。直接暴露数据细节给外部。

三、不使用迭代模式的缺点

以上方法1与方法2都可以实现对遍历,这样有问题呢?
  1. 容器类承担了太多功能:一方面需要提供添加删除等本身应有的功能;一方面还需要提供遍历访问功能。
  2. 往往容器在实现遍历的过程中,需要保存遍历状态,当跟元素的添加删除等功能夹杂在一起,很容易引起混乱和程序运行错误等。

四、使用迭代模式的应用

Iterator模式就是为了有效地处理按顺序进行遍历访问的一种设计模式,简单地说,Iterator模式提供一种有效的方法,可以屏蔽聚集对象集合的容器类的实现细节,而能对容器内包含的对象元素按顺序进行有效的遍历访问。
所以,Iterator模式的应用场景可以归纳为满足以下几个条件:
  1. 访问容器中包含的内部对象
  2.  按顺序访问

五、迭代模式的结构


六、迭代模式的角色和职责

Iterator(迭代器接口):该接口必须定义实现迭代功能的最小定义方法集,比如提供hasNext()和next()方法。
ConcreteIterator(迭代器实现类): 比如BookShelfIterator,迭代器接口Iterator的实现类。可以根据具体情况加以实现。
Aggregate(容器接口):定义基本功能以及提供类似Iterator iterator()的方法。
ConcreteAggregate(容器实现类): 比如BookShelf,容器接口的实现类。必须实现Iterator iterator()方法。

七、迭代模式的优点

  1. 实现功能分离,简化容器接口。让容器只实现本身的基本功能,把迭代功能委让给外部类实现,符合类的设计原则。
  2. 隐藏容器的实现细节。
  3. 为容器或其子容器提供了一个统一接口,一方面方便调用;另一方面使得调用者不必关注迭代器的实现细节。
  4. 可以为容器或其子容器实现不同的迭代方法或多个迭代方法。

八、代码实例

容器接口Aggregate

[java] view plain copy
  1. public interface Aggregate {      
  2.     public abstract Iterator iterator();      
  3. }   

迭代器接口类Iterator

[java] view plain copy
  1. public interface Iterator {      
  2.     public abstract boolean hasNext();      
  3.     public abstract Object next();      
  4. }     

Book.java

[java] view plain copy
  1. public class Book {      
  2.     private String name="";  
  3.       
  4.     public Book(String name) {      
  5.         this.name = name;      
  6.     }      
  7.           
  8.     /**   
  9.      * 获得书籍名称   
  10.      * @return String   
  11.      */      
  12.     public String getName() {      
  13.         return name;      
  14.     }      
  15. }   

容器接口实现类BookShelf

[java] view plain copy
  1. /**   
  2.  * 书架类   
  3.  * ConcreateAggregate 
  4.  */      
  5. public class BookShelf implements Aggregate{      
  6.     private Book[] books;      
  7.     private int last = 0;      
  8.           
  9.     //构造函数  
  10.     public BookShelf(int maxSize) {      
  11.         this.books = new Book[maxSize];      
  12.     }      
  13.   
  14.     //查找书籍  
  15.     public Book getBookAt(int index) {      
  16.         return books[index];      
  17.     }      
  18.           
  19.     //添加书籍      
  20.     public void appendBook(Book book) {      
  21.         this.books[last] = book;      
  22.         last++;      
  23.     }      
  24.       
  25.     //获得书架存书的数量      
  26.     public int getLength() {      
  27.         return books.length;      
  28.     }  
  29.   
  30.     //获得书架迭代器对象    
  31.     @Override  
  32.     public Iterator iterator() {      
  33.         return new BookShelfIterator(this);      
  34.     }        
  35. }     

迭代器接口实现类BookShelfIterator

[java] view plain copy
  1. //ConcreateIterator  
  2. ublic class BookShelfIterator implements Iterator{      
  3.    private BookShelf bookShelf;      
  4.    private int index;      
  5.          
  6.    public BookShelfIterator(BookShelf bookShelf) {      
  7.        this.bookShelf = bookShelf;      
  8.        this.index = 0;      
  9.    }      
  10.          
  11.    //检查是否还有下一本书      
  12.    public boolean hasNext() {      
  13.        if(index < bookShelf.getLength()) {      
  14.            return true;      
  15.        }      
  16.        else {      
  17.            return false;      
  18.        }      
  19.    }      
  20.    //返回指定位置的书籍      
  21.    public Object next() {      
  22.        Book book = bookShelf.getBookAt(index);      
  23.        index ++;      
  24.        return book;      
  25.    }      

主函数

[java] view plain copy
  1. public class Main {      
  2.     public static void main(String[] args) {      
  3.         //生成一个书架      
  4.         BookShelf bookShelf = new BookShelf(4);      
  5.         //向书架添加书籍      
  6.         bookShelf.appendBook(new Book("周恩来的晚年岁月"));      
  7.         bookShelf.appendBook(new Book("C++网络编程"));      
  8.         bookShelf.appendBook(new Book("J2EE网络编程精解"));      
  9.         bookShelf.appendBook(new Book("Java编程思想"));      
  10.               
  11.         //获得书架迭代器      
  12.         Iterator it = bookShelf.iterator();      
  13.         while(it.hasNext()) {      
  14.             Book book = (Book)it.next();      
  15.             System.out.println(book.getName());      
  16.         }      
  17.     }      
  18. }    

总结

总而言之,迭代器设计模式的总体思想就是“在容器实现类中实现对实体的增删改查操作,而在迭代器实现类中实现遍历操作。”

转载http://blog.csdn.net/xw13106209/article/details/6912873

0 0
原创粉丝点击