/*
* 迭代器模式(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#等面向对象编程语言中有着广泛的应用。这个模式的主要目标是允许用户遍历一个聚合对象(如数组、集合或列表)的所有元素,而无需了解底层的实现细节。下面将详细...
C#面向对象设计模式 (行为型模式) Iterator 迭代器模式 视频讲座下载
迭代器模式是软件设计模式中的一种行为模式,它在编程中扮演着重要的角色,尤其是在处理集合数据时。迭代器模式的核心思想是提供一种方法来顺序访问聚合对象的元素,而无需暴露其底层表示。这种模式使得用户可以在不...
迭代器模式(Iterator Pattern)是Java设计模式中的行为模式之一,它提供了一种方法来顺序访问聚合对象的元素,而又不暴露其底层表示。在Java中,迭代器模式被广泛应用于集合类,如ArrayList、LinkedList等,通过...
迭代器模式是软件设计模式中的行为模式之一,它在C++编程中有着广泛的应用。这个模式提供了一种方法来顺序访问聚合对象的元素,而无需暴露其底层表示。通过迭代器,用户可以遍历集合中的所有元素,而无需知道如何...
迭代器模式(IteratorPattern)是设计模式中的一种行为模式,它提供了一种顺序访问聚合对象元素的方法,同时又不暴露其底层表示。这种模式允许我们遍历集合对象的元素,而无需暴露其内部结构。在Java、C#等面向对象...
迭代器模式是软件开发中广泛使用的设计模式之一,特别是在处理聚合数据结构如数组、列表和集合时。迭代器模式可以提供一种统一的方式来遍历这些结构中的元素,从而使得开发者不需要关心聚合对象的内部实现细节。通过...
迭代器模式是软件设计模式中的一种行为模式,它允许我们顺序访问聚合对象的元素,而无需暴露其底层表示。在编程中,特别是面向对象编程中,迭代器模式扮演着非常重要的角色,它提供了统一的接口来遍历各种集合类型,...
### Iterator迭代器详解 #### 一、Iterator简介与概念 在Java编程语言中,`Iterator`接口是一个重要的组件,...无论是从设计模式的角度还是实际应用的角度来看,掌握`Iterator`的工作原理和使用方法都是非常重要的。
迭代器模式是软件设计模式中的一种行为模式,它在Android开发中被广泛应用,尤其是在处理集合对象的遍历操作时。这种模式提供了一种方法来顺序访问聚合对象的元素,而又不暴露其底层表示。在Java或Android编程中,...
迭代器模式(Iterator Pattern)和组合模式(Composite Pattern)是设计模式中的两种重要结构型模式,它们在软件设计中有着广泛的应用。这两种模式都属于GoF(Gang of Four)设计模式,旨在解决特定的问题,提升代码...
迭代器模式是软件设计模式中的一种行为模式,它允许我们顺序访问聚合对象的元素,而无需暴露其底层表示。在Java、C#等面向对象语言中,迭代器模式被广泛应用于容器类,如ArrayList、LinkedList等,使得我们可以方便...
根据提供的文件信息,我们可以深入探讨迭代器(Iterator)这一设计模式在Java中的应用与实现细节。迭代器模式是一种常用的设计模式,它允许我们以一种顺序访问集合对象的方式遍历其元素,而无需暴露该对象的内部表示...
迭代器模式是软件设计模式中的一种行为模式,它允许我们顺序访问聚合对象的元素,而无需暴露其底层表示。在“设计模式之迭代器模式(新)”中,我们将深入探讨这种模式的核心概念、实现方式以及它在实际编程中的应用...
迭代器设计模式是一种行为设计模式,它允许我们顺序访问聚合对象的元素,而又不暴露其底层表示。在Java、C++、Python等编程语言中,迭代器模式被广泛使用,为遍历各种容器提供了统一的接口。下面我们将深入探讨迭代...
迭代器设计模式是一种常用的行为设计模式,它提供了一种方法来顺序访问聚合对象的元素,而又不暴露其底层表示。这个“iterator-demo”应该是一个示例项目,用于演示如何在实际编程中应用迭代器模式。下面我们将深入...
### C++设计模式之迭代器(Iterator)模式详解 #### 一、引言 在软件开发过程中,设计模式是解决特定问题的一种通用解决方案。其中,迭代器模式是一种常用的模式,它提供了一种方法来访问一个容器对象中的各个元素...