迭代模式 Iterator Pattern

来源:互联网 发布:java中级招聘 编辑:程序博客网 时间:2024/05/17 16:53
一、什么是迭代模式
    Iterator模式也叫迭代模式,是行为模式之一,它把对容器中包含的内部对象的访问委让给外部类,使用Iterator(遍历)按顺序进行遍历访问的设计模式。

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

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

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

五、迭代模式的结构


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

Iterator(迭代器接口):

该接口必须定义实现迭代功能的最小定义方法集

比如提供hasNext()和next()方法。

 ConcreteIterator(迭代器实现类): 比如Itr.class

迭代器接口Iterator的实现类。可以根据具体情况加以实现。

 Aggregate(容器接口):

定义基本功能以及提供类似Iterator iterator()的方法。

 concreteAggregate(容器实现类): 比如AbstractList.class, BookList.java
容器接口的实现类。必须实现Iterator iterator()方法。
(注意:看Java的源代码,Iterator.class, Itr.class, AbstractList.class)

七、迭代模式的优点

1,实现功能分离,简化容器接口。让容器只实现本身的基本功能,把迭代功能委让给外部类实现,符合类的设计原则。

2,隐藏容器的实现细节。

3,为容器或其子容器提供了一个统一接口,一方面方便调用;另一方面使得调用者不必关注迭代器的实现细节。

4,可以为容器或其子容器实现不同的迭代方法或多个迭代方法。

Book.javapublic class Book {     private String ISBN;     private String name;     private double price;      public Book(String isbn, String name, double price) {         ISBN = isbn;         this.name = name;         this.price = price;     }      public String getISBN() {         return ISBN;     }      public void setISBN(String isbn) {         ISBN = isbn;     }      public String getName() {         return name;     }      public void setName(String name) {         this.name = name;     }      public double getPrice() {         return price;     }      public void setPrice(double price) {         this.price = price;     }      public void display() {         System.out.println("ISBN=" + ISBN + ",name=" + name + ",price" + price);     } }BookList.javaimport java.util.ArrayList; import java.util.Iterator; import java.util.List;   public class BookList {     private List<Book> bookList;     private int index;     private Iterator iterator;      public BookList() {         bookList = new ArrayList<Book>();     }      //添加书籍     public void addBook(Book book) {         bookList.add(book);     }      //删除书籍     public void deleteBook(Book book) {         int bookIndex = bookList.indexOf(book);         bookList.remove(bookIndex);     }  //  //判断是否有下一本书 //  public boolean hasNext() { //      if(index >= bookList.size()) { //          return false; //      } //      return true; //  } // //  //获得下一本书 //  public Book getNext() { //      return bookList.get(index++); //  }  //  public List<Book> getBookList() { //      return bookList; //  }      public Iterator Iterator() {         return new Itr();     }      private class Itr implements Iterator{          public boolean hasNext() {             if(index >= bookList.size()) {                 return false;             }             return true;         }          public Object next() {             return bookList.get(index++);         }          public void remove() {          }      }  }MainClass.javaimport java.util.Iterator; public class MainClss {     public static void main(String[] args) {         BookList bookList = new BookList();          Book book1 = new Book("010203","Java编程思想",90);         Book book2 = new Book("010204","Java从入门到精通",60);          bookList.addBook(book1);         bookList.addBook(book2);  //      while(bookList.hasNext()) { //          Book book = bookList.getNext(); //          book.display(); //      }  //      List<Book> bookDateList = bookList.getBookList(); //      for(int i = 0; i < bookDateList.size(); i++) { //          Book book = bookDateList.get(i); //          book.display(); //      }          Iterator iter = bookList.Iterator();         while(iter.hasNext()) {             Book book = (Book) iter.next();             book.display();         }       } }





原创粉丝点击