一,概述
定义:提供一种方法顺序访问一个聚合对象中各个元素,而又不暴漏该对象的内部表示。
作用:客户端可以不必知道数据集合的结构,而通过迭代器的接口来操作数据,不仅保护了数据结构,同时可以自定义数据的访问方式。
其实C++中的STL模板类中大量用到了此种设计模式!
二,示例
问题:售票员清点上车人数,然后挨个人遍历,让其买票。
class Program //客户端 { static void Main(string[] args) { ConcreteAggregate a = new ConcreteAggregate();//聚集类 a[0] = "大鸟"; a[1] = "小菜"; a[2] = "行李"; a[3] = "老外"; a[4] = "公交内部员工"; a[5] = "小偷"; Iterator i = new ConcreteIterator(a);//迭代器 //Iterator i = new ConcreteIteratorDesc(a); object item = i.First(); while (!i.IsDone())//遍历聚集类 { Console.WriteLine("{0} 请买车票!", i.CurrentItem()); i.Next(); } Console.Read(); } } abstract class Aggregate//抽象聚集类 { public abstract Iterator CreateIterator(); } class ConcreteAggregate : Aggregate//具体聚集类 { private IList<object> items = new List<object>(); public override Iterator CreateIterator() { return new ConcreteIterator(this); } public int Count { get { return items.Count; } } public object this[int index] { get { return items[index]; } set { items.Insert(index, value); } } } abstract class Iterator//抽象迭代器类(方便实现各种迭代策略) { public abstract object First(); public abstract object Next(); public abstract bool IsDone(); public abstract object CurrentItem(); } class ConcreteIterator : Iterator//具体迭代器类(升序访问) { private ConcreteAggregate aggregate; private int current = 0; public ConcreteIterator(ConcreteAggregate aggregate) { this.aggregate = aggregate; } public override object First() { return aggregate[0]; } public override object Next() { object ret = null; current++; if (current < aggregate.Count) { ret = aggregate[current]; } return ret; } public override object CurrentItem() { return aggregate[current]; } public override bool IsDone() { return current >= aggregate.Count ? true : false; } } class ConcreteIteratorDesc : Iterator//具体迭代器类(降序访问) { private ConcreteAggregate aggregate; private int current = 0; public ConcreteIteratorDesc(ConcreteAggregate aggregate) { this.aggregate = aggregate; current = aggregate.Count - 1; } public override object First() { return aggregate[aggregate.Count - 1]; } public override object Next() { object ret = null; current--; if (current >= 0) { ret = aggregate[current]; } return ret; } public override object CurrentItem() { return aggregate[current]; } public override bool IsDone() { return current < 0 ? true : false; } }
您还没有登录,请您登录后再发表评论
设计模式专题之(二十三)迭代器模式---设计模式迭代器模式示例代码(python--c++)
设计模式迭代器模式PPT学习教案.pptx
设计模式之迭代器模式 设计模式之迭代器模式 设计模式之迭代器模式
提供一种方法顺序访问一个聚合对象中各个元素,而又不需暴露该对象的内部表示。
设计模式之迭代器模式(新) 设计模式之迭代器模式(新)
设计模式的迭代器模式的例子,希望对大家有用~~~~~~~~
23种设计模式之迭代器模式对迭代器模式进行了简单的介绍,并附带了例子程序,和大家分享
matlab开发-设计模式迭代器行为。迭代器行为设计模式的matlab®oop实现
迭代器设计模式代码示例--以最简单的代码诠释迭代器设计模式
设计模式--迭代器模式java例子
C#设计模式基础示例之迭代器模式,很基础的教程,初学者使用
这份文档以例子的形式讲诉了设计模式之迭代器与组合模式,希望可以帮助学习的人!
设计模式-迭代器模式(讲解及其实现代码)
java常用设计模式-迭代器模式
java设计模式--迭代器模式,理解这个例子就完全理解迭代器啦
java设计模式之迭代器模式,从生活中的例子举例说明迭代器模式。
迭代器(Iterator) 用意:可以顺序地访问一个集合中的元素而不必暴露集合中的内部表象。
【Java设计模式】(1)迭代器模式Iterator(代码)
相关推荐
设计模式专题之(二十三)迭代器模式---设计模式迭代器模式示例代码(python--c++)
设计模式迭代器模式PPT学习教案.pptx
设计模式之迭代器模式 设计模式之迭代器模式 设计模式之迭代器模式
提供一种方法顺序访问一个聚合对象中各个元素,而又不需暴露该对象的内部表示。
设计模式之迭代器模式(新) 设计模式之迭代器模式(新)
设计模式的迭代器模式的例子,希望对大家有用~~~~~~~~
23种设计模式之迭代器模式对迭代器模式进行了简单的介绍,并附带了例子程序,和大家分享
matlab开发-设计模式迭代器行为。迭代器行为设计模式的matlab®oop实现
迭代器设计模式代码示例--以最简单的代码诠释迭代器设计模式
设计模式--迭代器模式java例子
C#设计模式基础示例之迭代器模式,很基础的教程,初学者使用
这份文档以例子的形式讲诉了设计模式之迭代器与组合模式,希望可以帮助学习的人!
设计模式-迭代器模式(讲解及其实现代码)
java常用设计模式-迭代器模式
java设计模式--迭代器模式,理解这个例子就完全理解迭代器啦
java设计模式之迭代器模式,从生活中的例子举例说明迭代器模式。
迭代器(Iterator) 用意:可以顺序地访问一个集合中的元素而不必暴露集合中的内部表象。
【Java设计模式】(1)迭代器模式Iterator(代码)