`
guafei
  • 浏览: 328241 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

迭代器模式

阅读更多
【迭代器模式】 迭代器可以顺序访问一个聚集中的元素而不必显露聚集的内部对象。多个对象聚在一起形成的总体称为聚集,聚集对象是能够包容一组对象的容器对象。迭代器模式 将迭代逻辑封装到一个独立的对象中,从而与聚集本身隔开。迭代算法独立于聚集对象,修改迭代算法不会对聚集对象产生任何影响,实现程序的松耦合。


1.Aggregate接口所声明的方法只有iterator方法一个,这是为了建立一个对对应聚合的
iterator
Java代码 
1. package com.pattern.iterator;  
2.  
3. public interface Aggregate {  
4.     public abstract Iterator iterator();  
5. } 


2.iterator接口,执行元素递增,具有类似循环变量的功能。
Java代码 
1. package com.pattern.iterator;  
2. public interface Iterator {  
3.     public abstract boolean hasNext();  
4.     public abstract Object next();  
5. } 



3. 书籍类
Java代码 
1. package com.pattern.iterator;  
2. public class Book {  
3.     private String name="";  
4.  
5.     public Book(String name) {  
6.         this.name = name;  
7.     }  
8.       
9.     /** 
10.      * 获得书籍名称 
11.      * @return String 
12.      */ 
13.     public String getName() {  
14.         return name;  
15.     }  
16. } 


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

5.书架迭代器类
Java代码 
1. package com.pattern.iterator;  
2. public 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.     }  
26. } 



6.测试类
Java代码 
package com.pattern.iterator;  
 
public class Main {  
    public static void main(String[] args) {  
         //生成一个书架  
         BookShelf bookShelf = new BookShelf(4);  
         //向书架添加书籍  
         bookShelf.appendBook(new Book("Effective Java"));  
        bookShelf.appendBook(new Book("J2EE"));  
         bookShelf.appendBook(new Book("Head First Design Pattern"));  
         bookShelf.appendBook(new Book("Thinking in Java"));  
        
      //获得书架迭代器  
       Iterator it = bookShelf.iterator();  
        while(it.hasNext()) {  
           Book book = (Book)it.next();  
           System.out.println(book.getName());  
       }  
    }  
}
分享到:
评论

相关推荐

    设计模式之迭代器模式(Iterator)

    迭代器模式是软件设计模式中的一种行为模式,它在编程中扮演着重要的角色,尤其是在处理集合数据时。迭代器模式的核心思想是提供一种方法来顺序访问聚合对象的元素,而无需暴露其底层表示。这种模式使得用户可以在不...

    23钟设计模式之迭代器模式模式

    迭代器模式是软件开发中广泛使用的设计模式之一,特别是在处理聚合数据结构如数组、列表和集合时。迭代器模式可以提供一种统一的方式来遍历这些结构中的元素,从而使得开发者不需要关心聚合对象的内部实现细节。通过...

    迭代器模式Demo

    迭代器模式是一种设计模式,它在软件工程中扮演着重要的角色,特别是在处理集合或容器类对象的遍历操作时。这种模式提供了一种方法来顺序访问聚合对象的元素,而无需暴露其底层表示。在Java、C#等面向对象语言中,...

    设计模式的迭代器模式的例子

    迭代器模式是软件设计模式中的一种行为模式,它允许我们顺序访问聚合对象的元素,而无需暴露其底层表示。在Java、C#等面向对象语言中,迭代器模式被广泛应用于容器类,如ArrayList、LinkedList等,使得我们可以方便...

    设计模式-迭代器模式(讲解及其实现代码)

    迭代器模式是一种行为设计模式,它提供了一种方法来顺序访问聚合对象的元素,而无需暴露其底层表示。这种模式允许我们遍历集合中的每个元素,同时保持集合本身抽象,不需了解其内部结构。 在Java、C#等面向对象语言...

    设计模式之迭代器模式

    迭代器模式是一种行为设计模式,它提供了一种方法来顺序访问聚合对象的元素,而无需暴露其底层表示。在Java中,迭代器模式是通过接口实现的,这使得我们可以遍历任何实现了`Iterable`接口的对象,例如集合框架中的`...

    设计模式(C#)之迭代器模式(Iterator Pattern)

    迭代器模式是软件设计模式中的一种行为模式,它在C#等面向对象编程语言中有着广泛的应用。这个模式的主要目标是允许用户遍历一个聚合对象(如数组、集合或列表)的所有元素,而无需了解底层的实现细节。下面将详细...

    组合模式二叉树,前序、中序、后续,迭代器模式访问遍历

    在这个主题中,我们主要探讨了如何利用组合模式(Composite Pattern)构建二叉树,并通过迭代器模式(Iterator Pattern)来实现对树的遍历,包括前序、中序和后序遍历。这些是设计模式中的经典应用,对于理解和掌握...

    迭代器模式代码示例

    迭代器模式是一种设计模式,属于行为设计模式,它允许我们顺序访问聚合对象的元素,而无需暴露其底层表示。在Java、C#等面向对象语言中,迭代器模式被广泛应用于容器类,如ArrayList、LinkedList等,使得我们可以...

    65丨迭代器模式(上):相比直接遍历集合数据,使用迭代器有哪些优势?1

    迭代器模式是一种行为设计模式,主要目的是在不暴露集合内部结构的情况下,允许外部代码遍历集合的所有元素。这种模式将遍历操作从集合类中分离出来,实现了数据结构和遍历机制的解耦。在大多数编程语言中,迭代器...

    迭代器模式demo

    迭代器模式是一种行为设计模式,它允许我们顺序访问聚合对象的元素,而无需暴露其底层表示。在Java、Python、C#等编程语言中,迭代器模式被广泛应用于集合类,如ArrayList、LinkedList等,提供了统一的遍历接口,...

    Headfirst(九)迭代器模式

    迭代器模式是一种设计模式,它提供了一种方法来顺序访问聚合对象的元素,而又不暴露其底层表示。在Headfirst的第九章中,这个模式通过C++语言进行了深入的探讨和实现,同时辅以UML类图进行可视化展示,帮助读者更好...

    (行为型模式) Iterator 迭代器模式

    ### (行为型模式) Iterator 迭代器模式 #### 概述 在软件工程领域,设计模式被广泛应用于解决常见的编程问题。其中,“迭代器模式”作为一种行为型设计模式,在处理集合类对象时发挥着重要作用。本文将详细介绍...

    java体系结构之迭代器模式.rar

    迭代器模式是软件设计模式中的一种行为模式,它允许我们顺序访问聚合对象的元素,而无需暴露其底层表示。在Java中,迭代器模式广泛应用于集合框架,如List、Set和Map接口,使得程序员可以方便地遍历集合中的元素。 ...

    【Java设计模式】(1)迭代器模式Iterator

    迭代器模式(Iterator Pattern)是Java设计模式中的行为模式之一,它提供了一种方法来顺序访问聚合对象的元素,而又不暴露其底层表示。在Java中,迭代器模式被广泛应用于集合类,如ArrayList、LinkedList等,通过...

    设计模式--迭代器模式java例子

    迭代器模式是一种行为设计模式,它允许我们顺序访问聚合对象的元素,而无需暴露其底层表示。在Java中,迭代器模式广泛应用于集合框架,如ArrayList、LinkedList等。本示例将深入探讨如何在Java中实现和使用迭代器...

    一个小小例子让你读懂迭代器模式,

    迭代器模式是软件设计模式中的一种,它在对象集合的遍历访问中起着关键作用。这个模式的主要目的是提供一种方法来顺序访问聚合对象的元素,而无需暴露其底层表示。迭代器模式允许你遍历任何聚合对象,无论它的内部...

    第20章_迭代器模式.ppt

    一个聚合对象,如一个列表(List)或者一个集合(Set),应该提供一种方法来让别人可以访问它...怎样遍历一个聚合对象,又不需要了解聚合对象的内部结构,还能够提供多种不同的遍历方式,这就是迭代器模式所要解决的问题。

Global site tag (gtag.js) - Google Analytics