`

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

阅读更多
/*
 * 迭代器模式(Iterator)
 *
 * 类似于集合中的Iterator,使用迭代器来统一不同集合对象的遍历方式,
 * 隐藏内部细节,用一个抽象迭代器,每个具体的集合类来实现特有的迭代器。
 */

package model;

public class TestIterator {
    public static void main(String[] args) {
        Stack s = new Stack();
        s.push("Liucy");
        s.push("Huxz");
        s.push("George");
        LinkedList l = new LinkedList();
        l.addFirst("Liucy");
        l.addFirst("Huxz");
        l.addFirst("George");
        print(l.iterator());
    }

    public static void print(Itr it) {
        while (it.hasNext()) {
            System.out.println(it.next());
        }
    }
}

interface Itr {
    boolean hasNext();

    Object next();
}

class Stack {
    Object[] os = new Object[10];
    int index = 0;

    private void expand() {
        Object[] os2 = new Object[os.length * 2];
        System.arraycopy(os, 0, os2, 0, os.length);
        os = os2;
    }

    public void push(Object o) {
        if (index == os.length)
            expand();
        os[index] = o;
        index++;
    }

    public Object pop() {
        index--;
        Object o = os[index];
        os[index] = null;
        return o;
    }

    private class StackItr implements Itr {
        int cursor = 0;

        public boolean hasNext() {
            return cursor < index;
        }

        public Object next() {
            return os[cursor++];
        }
    }

    public Itr iterator() {
        return new StackItr();
    }
}

class LinkedList {
    private class Node {
        Object o;
        Node next;

        public Node(Object o) {
            this.o = o;
        }

        public void setNext(Node next) {
            this.next = next;
        }

        public Node getNext() {
            return this.next;
        }
    }

    Node head;

    public void addFirst(Object o) {
        Node n = new Node(o);
        n.setNext(head);
        head = n;
    }

    public Object removeFirst() {
        Node n = head;
        head = head.getNext();
        return n.o;
    }

    class LinkedListItr implements Itr {
        Node currentNode = head;

        public boolean hasNext() {
            return this.currentNode != null;
        }

        public Object next() {
            Node n = currentNode;
            currentNode = currentNode.getNext();
            return n.o;
        }
    }

    public Itr iterator() {
        return new LinkedListItr();
    }
}
 
分享到:
评论

相关推荐

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

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

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

    C#面向对象设计模式 (行为型模式) Iterator 迭代器模式 视频讲座下载

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

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

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

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

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

    迭代器模式是软件设计模式中的行为模式之一,它在C++编程中有着广泛的应用。这个模式提供了一种方法来顺序访问聚合对象的元素,而无需暴露其底层表示。通过迭代器,用户可以遍历集合中的所有元素,而无需知道如何...

    IteratorPattern 迭代设计模式

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

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

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

    设计模式之迭代器模式

    迭代器模式是软件设计模式中的一种行为模式,它允许我们顺序访问聚合对象的元素,而无需暴露其底层表示。在编程中,特别是面向对象编程中,迭代器模式扮演着非常重要的角色,它提供了统一的接口来遍历各种集合类型,...

    Iterator迭代器讲解

    ### Iterator迭代器详解 #### 一、Iterator简介与概念 在Java编程语言中,`Iterator`接口是一个重要的组件,...无论是从设计模式的角度还是实际应用的角度来看,掌握`Iterator`的工作原理和使用方法都是非常重要的。

    Android设计模式之--迭代器模式

    迭代器模式是软件设计模式中的一种行为模式,它在Android开发中被广泛应用,尤其是在处理集合对象的遍历操作时。这种模式提供了一种方法来顺序访问聚合对象的元素,而又不暴露其底层表示。在Java或Android编程中,...

    Head First 设计模式 (九) 迭代器与组合模式(Iterator & Composite pattern) C++实现

    迭代器模式(Iterator Pattern)和组合模式(Composite Pattern)是设计模式中的两种重要结构型模式,它们在软件设计中有着广泛的应用。这两种模式都属于GoF(Gang of Four)设计模式,旨在解决特定的问题,提升代码...

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

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

    迭代器Iterator.txt

    根据提供的文件信息,我们可以深入探讨迭代器(Iterator)这一设计模式在Java中的应用与实现细节。迭代器模式是一种常用的设计模式,它允许我们以一种顺序访问集合对象的方式遍历其元素,而无需暴露该对象的内部表示...

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

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

    迭代器设计模式示例

    迭代器设计模式是一种行为设计模式,它允许我们顺序访问聚合对象的元素,而又不暴露其底层表示。在Java、C++、Python等编程语言中,迭代器模式被广泛使用,为遍历各种容器提供了统一的接口。下面我们将深入探讨迭代...

    iterator-demo 迭代器设计模式demo

    迭代器设计模式是一种常用的行为设计模式,它提供了一种方法来顺序访问聚合对象的元素,而又不暴露其底层表示。这个“iterator-demo”应该是一个示例项目,用于演示如何在实际编程中应用迭代器模式。下面我们将深入...

    C++设计模式课件21_Iterator_迭代器.pdf

    ### C++设计模式之迭代器(Iterator)模式详解 #### 一、引言 在软件开发过程中,设计模式是解决特定问题的一种通用解决方案。其中,迭代器模式是一种常用的模式,它提供了一种方法来访问一个容器对象中的各个元素...

Global site tag (gtag.js) - Google Analytics