迭代模式 Iterator Pattern

一、什么是迭代模式
    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.java
public 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.java
import 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.java
import 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(); 
        } 
 
 
    } 
}





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值