`

设计模式之迭代器模式

 
阅读更多
迭代器模式
提供一种可以遍历聚合对象的方式,又称cursor模式。迭代器模式(Iterator)就是分离了聚合对象的遍历行为,抽象出一个迭代器来负责这样既可以做到不暴露集合的内部结构,又可让外部代码透明的访问集合内部数据。
聚合对象:存储数据
迭代器:遍历数据
 
结构图
聚合抽象类一般以内部类的方式存储
 
/**
 * 定义迭代器接口
 */
public interface MyIterator {
    void first();
    void next();
    boolean hasNext();

    boolean isFirst();
    boolean isLast();

    Object getCurrentObject();
}


/
 * 聚合类
 */
public class ConcreteAggregate {

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


    public void addConcrete(Object obj){
        list.add(obj);
    }

    public MyIterator createIterator(){
        return new ConcretIterator();
    }

    private class ConcretIterator implements MyIterator{

        private int cursor; //定义游标,用于记录变量时的位置

        @Override
        public void first() {
            cursor = 0;
        }

        @Override
        public void next() {
            if(cursor == list.size()){
                return;
            }
            cursor++ ;
        }

        @Override
        public boolean hasNext() {
            if(cursor< list.size()){
                return true;
            }
            return false;
        }

        @Override
        public boolean isFirst() {
            return cursor == 0?true:false;
        }

        @Override
        public boolean isLast() {
            return cursor == list.size()? true:false;

        }

        @Override
        public Object getCurrentObject() {
            return list.get(this.cursor);
        }
    }
}


public class Client {

    public static void main(String[] args){
        ConcreteAggregate ca = new ConcreteAggregate();
        ca.addConcrete("zhang");
        ca.addConcrete("lisi");
        ca.addConcrete("wangWS");

        MyIterator iterator = ca.createIterator();
        while (iterator.hasNext()){
            System.out.println(iterator.getCurrentObject());
            iterator.next();
        }
    }
}

 
 
  • 大小: 47.7 KB
分享到:
评论

相关推荐

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

    迭代器模式是23种设计模式之一,属于行为型模式。它提供了一种访问聚合对象元素的方式,而不需要暴露该对象的内部实现。迭代器模式的主要目的是让开发者能够轻松地遍历聚合对象中的元素,而不需要关心对象的内部实现...

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

    迭代器模式是软件设计模式中的一种行为模式,它允许我们顺序访问聚合对象的元素,而无需暴露其底层表示。在“设计模式之迭代器模式(新)”中,我们将深入探讨这种模式的核心概念、实现方式以及它在实际编程中的应用...

    Android编程设计模式之迭代器模式详解

    Android编程设计模式之迭代器模式详解 Android编程设计模式之迭代器模式是Android开发中常用的设计模式之一。迭代器模式(Iterator Pattern)又称为游标(Cursor)模式,是行为型设计模式之一。该模式的主要目的是...

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

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

    深入浅出Java设计模式之迭代器模式 _天极网

    深入浅出Java设计模式之迭代器模式 _天极网

    java设计模式之迭代器模式

    迭代器模式是软件设计模式中的一种行为模式,它允许我们顺序访问聚合对象的元素,而无需暴露其底层表示。在Java中,迭代器模式广泛应用于集合框架,如List、Set和Map接口,提供了遍历元素的方法。让我们深入探讨这个...

    深入浅出学习Java设计模式之迭代器模式

    迭代器模式是一种设计模式,它的主要目的是在不暴露容器内部结构的情况下,允许用户遍历容器中的元素。在Java中,这种模式被广泛应用于集合类,如List、Set和Map等,通过Iterator接口来实现对集合的遍历。 迭代器...

    设计模式之迭代器与组合模式

    这份文档以例子的形式讲诉了设计模式之迭代器与组合模式,希望可以帮助学习的人!

    深入浅出学习Java设计模式之迭代器模式[参考].pdf

    迭代器模式是一种设计模式,它的主要目的是在不暴露容器对象的内部细节的前提下,提供一种方法来遍历容器中的元素。这种模式遵循了“单一职责原则”,使得容器专注于管理其内部元素,而遍历的责任则交给迭代器来处理...

    Java 23种设计模式20迭代器模式.pdf

    ### Java 23种设计模式之迭代器模式 #### 模式动机与定义 迭代器模式(Iterator Pattern)是设计模式中的一种行为型模式,它主要用于处理聚合对象(如列表、集合等)。此模式的核心目的是提供一种方法来访问聚合...

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

    C++设计模式之迭代器模式(Iterator) 迭代器模式是一种常用的C++设计模式,主要用于访问容器中的元素,而不需要了解容器的内部结构。该模式提供了一种顺序访问容器中元素的方法,无需了解容器的内部类型和结构。 ...

    Python设计模式之迭代器模式原理与用法实例分析

    本文实例讲述了Python设计模式之迭代器模式原理与用法。分享给大家供大家参考,具体如下: 迭代器模式(Iterator Pattern):提供方法顺序访问一个聚合对象中各元素,而又不暴露该对象的内部表示. 下面是一个迭代器模式...

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

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

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

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

    Java设计模式之迭代器模式_动力节点Java学院整理

    Java设计模式之迭代器模式 迭代器模式是一种行为类模式,它提供了一种方法来访问容器对象中的各个元素,而不需要暴露该对象的内部细节。这种模式广泛应用于Java语言中,是 Java 中使用最多的一种模式。 迭代器模式...

Global site tag (gtag.js) - Google Analytics