`

迭代器模式

 
阅读更多

迭代器模式:

在软件构建过程中,集合对象内部结构常常变化各异(比如各种不同的集合对象list,set,map)。但对于这些集合对象,我们希望在不暴露其内部结构的同时,可以让外部客户代码透明地访问其中包含的元素;在面向对象技术中,将这种遍历机制抽象为“迭代器对象”,它为“应对变化中的集合对象”提供了一种优雅的方法。

 

适用性:

1.访问一个聚合对象的内容而无需暴露它的内部表示。

2.支持对聚合对象的多种遍历。

3.为遍历不同的聚合结构提供一个统一的接口(即, 支持多态迭代)。

 

 

 

/** 

 * 聚集抽象类 

 */  

public abstract class Aggregate {  

 

    // 创建迭代器  

    public abstract Iterator createIteraotr();  

 

}  

 

Java代码  

/** 

 * 具体的聚集类,继承聚集抽象类Aggregate 

 */  

public class ConcreteAggregate extends Aggregate{  

 

    // 声明一个List泛型变量,用于存放聚合对象  

    private List<Object> items = new ArrayList<Object>();  

    @Override  

    public Iterator createIteraotr() {        

        return new ConcreteIterator(this);  

    }  

    // 返回集合总个数  

    public int count(){  

        return items.size();  

    }  

    public List<Object> getItems() {  

        return items;  

    }  

    public void setItems(List<Object> items) {  

        this.items = items;  

    }  

}  

 

Java代码  

/** 

 * 迭代器抽象类 

 */  

public abstract class Iterator {  

 

    // 开始对象  

    public abstract Object first();  

    // 下一个对象  

    public abstract Object next();  

    // 当前对象  

    public abstract Object currentItem();  

    // 是否到结尾  

    public abstract boolean isDone();  

}  

 

Java代码  

/** 

 * 具体的迭代器类,继承迭代器抽象类Iterator 

 */  

public class ConcreteIterator extends Iterator{  

 

    // 定义一个具体的聚集对象  

    private ConcreteAggregate aggregate;  

    private int current =0 ;  

 

    // 初始化时将具体的聚集对象传入  

    public ConcreteIterator(ConcreteAggregate aggregate){  

        this.aggregate =aggregate;  

    }  

 

    @Override  

    public Object currentItem() {  

        // 返回当前的聚集对象  

        return aggregate.getItems().get(current);  

    }  

 

    @Override  

    public Object first() {  

        // 得到聚集的第一个对象  

        return aggregate.getItems().get(0);  

    }  

 

    @Override  

    public boolean isDone() {  

        // 判断当前是否遍历到结尾,到结尾返回true  

        return current>=aggregate.count()?true:false;  

    }  

 

    @Override  

    public Object next() {  

 

        // 得到聚集的下一个对象  

        Object ref = null;  

        current++;  

        if(current<aggregate.count()){  

            ref = aggregate.getItems().get(current);  

        }  

        return ref;  

    }  

}  

 

Java代码  

/** 

 * 反向遍历的具体的迭代器类,继承迭代器抽象类Iterator 

 */  

public class ConcreteIteratorDesc extends Iterator{  

 

    // 定义一个具体的聚集对象  

    private ConcreteAggregate aggregate;  

    private int current =0 ;  

 

    // 初始化时将具体的聚集对象传入  

    public ConcreteIteratorDesc(ConcreteAggregate aggregate){  

        this.aggregate =aggregate;  

        current = aggregate.count()-1;  

    }  

 

    @Override  

    public Object currentItem() {  

        // 返回当前的聚集对象  

        return aggregate.getItems().get(current);  

    }  

 

    @Override  

    public Object first() {  

        // 得到聚集的第一个对象  

        return aggregate.getItems().get(aggregate.count()-1);  

    }  

 

    @Override  

    public boolean isDone() {  

        // 判断当前是否遍历到结尾,到结尾返回true  

        return current<0?true:false;  

    }  

 

    @Override  

    public Object next() {  

 

        // 得到聚集的下一个对象  

        Object ref = null;  

        current--;  

        if(current>=0){  

            ref = aggregate.getItems().get(current);  

        }  

        return ref;  

    }  

}  

 

Java代码  

public class Main {  

 

    public static void main(String[] args) {  

 

        // 聚集对象(公交车)  

        ConcreteAggregate a = new ConcreteAggregate();  

 

        // 对象集合(新上来的乘客)  

        List<Object> items = new ArrayList<Object>();  

        items.add("大鸟");  

        items.add("小菜");  

        items.add("行李");  

        items.add("老外");  

        items.add("公交内部员工");  

        items.add("小偷");          

        a.setItems(items);  

 

        // 迭代器对象  

        Iterator i = new ConcreteIterator(a);  

 

        // 迭代器第一个对象(从第一个乘客开始)  

        Object item = i.first();  

        while(!i.isDone()){  

            System.out.println(i.currentItem()+"请买车票");  

            i.next();  

        }  

        System.out.println("------------反向遍历---------------");  

 

        //-----反向遍历-------------------  

        Iterator iDesc = new ConcreteIteratorDesc(a);  

        // 迭代器第一个对象(从最后一个乘客开始)  

        Object item2 = iDesc.first();  

        while(!iDesc.isDone()){  

            System.out.println(iDesc.currentItem()+"请买车票");  

            iDesc.next();  

        }  

    }  

}  

分享到:
评论

相关推荐

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

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

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

    迭代器模式 迭代器模式是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