`
raymond.chen
  • 浏览: 1419910 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

迭代器模式(Iterator Pattern)

阅读更多

提供一种方法访问一个容器(container)对象中各个元素,而又不需暴露该对象的内部细节。

 

在迭代器模式中,具体迭代器角色和具体容器角色是耦合在一起的 —— 遍历算法是与容器的内部细节紧密相关的。为了使客户程序从与具体迭代器角色耦合的困境中脱离出来,避免具体迭代器角色的更换给客户程序带来的修改,迭代器模式抽象了具体迭代器角色,使得客户程序更具一般性和重用性。这被称为多态迭代。

 

迭代器模式给容器的应用带来以下好处:
      1、支持以不同的方式遍历一个容器角色。根据实现方式的不同,效果上会有差别。
      2、简化了容器的接口。但是在java Collection中为了提高可扩展性,容器还是提供了遍历的接口。
      3、对同一个容器对象,可以同时进行多个遍历。因为遍历状态是保存在每一个迭代器对象中的。


 

聚合接口类:

public interface Aggregate<E>{
	/**
	 * Iterator的泛型由Aggregate决定
	 */
	public Iterator<E> createIterator(); 
	
	public int length();
	
	public E get(int index);
	
	public void add(E obj);
}

 

聚合实现类:

public class ConcreteAggregate<E> implements Aggregate<E>{
	private List<E> items = new ArrayList<E>();
	
	public Iterator<E> createIterator() {
		return new ConcreteIterator<E>(this); 
	}
	
	public int length(){
		return items.size();
	}
	
	public E get(int index){
		return (E)items.get(index);
	}
	
	public void add(E obj){
		items.add(obj);
	}
}

 

遍历器接口类:

public interface Iterator<E>{
	public E first();
	
	public boolean hasNext();
	
	public E next();
	
	public E current();
}

 

遍历器实现类:

public class ConcreteIterator<E> implements Iterator<E>{
	private Aggregate<E> aggregate;
	private int currentIndex = 0; //遍历状态
	
	public ConcreteIterator(Aggregate<E> aggregate){
		this.aggregate = aggregate;
	}

	public E first() {
		currentIndex = 0;
		if(hasNext()){
			return aggregate.get(currentIndex);
		}else{
			return null;
		}
	}

	public boolean hasNext() {
		return (currentIndex < aggregate.length());
	}
	
	public E next() {
		currentIndex++;
		if(hasNext()){
			return aggregate.get(currentIndex);
		}else{
			return null;
		}
	}
	
	public E current(){
		return aggregate.get(currentIndex);
	}
}

 

测试类:

public class Test {
	public static void main(String[] args) {
		Aggregate<String> a = new ConcreteAggregate<String>();
		a.add("111");
		a.add("222");
		a.add("333");
		
		Iterator<String> it = a.createIterator();
		for(String s=it.first();it.hasNext();s=it.next()){
			System.out.println(s);
		}
	}
}

 

  • 大小: 37.3 KB
0
0
分享到:
评论

相关推荐

    迭代器模式(Iterator Pattern)原理图

    迭代器模式(Iterator Pattern)是设计模式中的一种行为模式,它允许顺序访问一个聚合对象中的各个元素,而又不需要暴露该对象的内部表示。迭代器模式提供了一种方法,可以顺序地访问一个聚合对象中的各个元素,而又...

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

    提供一种方法顺序访问一个聚合对象中各个元素,而又不需暴露该对象的内部表示。

    Java24种设计模式,Java24种设计模式,24种设计模式,学会了这24种设计模式,可以打遍天下无敌手,设计模式非常重要

    14、迭代器模式ITERATOR PATTERN 15、组合模式COMPOSITE PATTERN 16、观察者模式OBSERVER PATTERN 17、责任链模式 18、访问者模式VISITOR PATTERN 19、状态模式 20、原型模式 21、中介者模式 22、解释器模式 23、...

    C#迭代器模式(Iterator Pattern)实例教程

    主要介绍了C#迭代器模式(Iterator Pattern),包括了迭代器的适用范围及用法实例,需要的朋友可以参考下

    设计模式(十七)——迭代器模式(Iterator Pattern)

    迭代器模式(Iterator Pattern) 基本介绍 迭代器模式,提供一种遍历集合元素的统一接口,用一致的方法遍历集合元素,不需要知道集合对象的底层表示,即:不暴露其内部的结构。 提供一种可以遍历聚合对象的方式。又...

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

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

    设计模式_迭代器模式.zip

    迭代器模式(Iterator Pattern)是 Java 和 .Net 编程环境中非常常用的设计模式。这种模式用于顺序访问集合对象的元素,不需要知道集合对象的底层表示。 迭代器模式属于行为型模式。 迭代器模式 java demo

    .NET设计模式(18):迭代器模式(IteratorPattern)

    Iterator模式就是分离了集合对象的遍历行为,抽象出一个迭代器类来负责,这样既可以做到不暴露集合的内部结构,又可让外部代码透明的访问集合内部的数据。提供一种方法顺序访问一个聚合对象中各个元素,而又不需暴露...

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

    迭代器模式(Iterator Pattern):提供方法顺序访问一个聚合对象中各元素,而又不暴露该对象的内部表示. 下面是一个迭代器模式的demo: #!/usr/bin/env python # -*- coding:utf-8 -*- __author__ = 'Andy' """ 大话...

    C#版 24种设计模式

    备忘录模式(Memento Pattern) 策略模式(Strategy Pattern) 抽象工厂模式(Abstract Factory Pattern) 代理模式(Proxy Pattern) 单例模式(Singleton Pattern) 迭代器模式(Iterator Pattern) 访问者模式(Visitor ...

    java设计模式--迭代器设计模式.docx

    迭代器模式(Iterator Pattern)是一种非常常用的设计模式,这种模式用于顺序访问集合对象的元素,不需要知道集合对象的底层表示。迭代器模式属于行为型模式。 介绍 意图: 提供一种方法顺序访问一个聚合对象中各个...

    迭代器模式

    迭代器模式(Iterator Pattern)是 Java 和 .Net 编程环境中非常常用的设计模式。这种模式用于顺序访问集合对象的元素,不需要知道集合对象的底层表示。

    用Java实现23种设计模式

    迭代器模式(Iterator Pattern) 中介者模式(Mediator Pattern) 备忘录模式(Memento Pattern) 观察者模式(Observer Pattern) 状态模式(State Pattern) 空对象模式(Null Object Pattern) 策略模式...

    C#设计模式_设计模式_C#_

    迭代器模式(Iterator Pattern) 16. 观察者模式(Observer Pattern) 17. 解释器模式(Interpreter Pattern) 18. 中介者模式(Mediator Pattern) 19. 职责链模式(Chain of Responsibility Pattern) 20. 备忘录模式...

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

    迭代器模式(Iterator Pattern)又称为游标(Cursor)模式,是行为型设计模式之一。迭代器模式算是一个比较古老的设计模式,其源于对容器的访问,比如Java中的List、Map、数组等,我们知道对容器对象的访问必然会...

    Java设计模式,并加上个人理解

    1. 设计模式 1.1 含义 1.2 作用 1.3 设计原则 ...14. 迭代器模式 (Iterator Pattern) 15. 享元模式 (Flyweight Pattern) 16. 桥接模式 (Bridge Pattern) 17. 观察者模式 (Observer Pattern)

    C#设计模式(23种设计模式)

    迭代器模式(Iterator Pattern) 行为型: 16. 观察者模式(Observer Pattern) 17. 解释器模式(Interpreter Pattern) 18. 中介者模式(Mediator Pattern) 19. 职责链模式(Chain of Responsibility Pattern) ...

    设计模式PPT

     迭代器模式(Iterator Pattern)  中介者模式(Mediator Pattern)  备忘录模式(Memento Pattern)  观察者模式(Observer Pattern)  状态模式(State Pattern)  策略模式(Strategy Pattern)  ...

    设计模式代码——c#

    15. 迭代器模式(Iterator Pattern) 16. 观察者模式(Observer Pattern) 17. 解释器模式(Interpreter Pattern) 18. 中介者模式(Mediator Pattern) 19. 职责链模式(Chain of Responsibility Pattern) 20. ...

Global site tag (gtag.js) - Google Analytics