原文:乐在其中设计模式(C#) - 迭代器模式(Iterator Pattern)

[索引页][源码下载]

乐在其中设计模式(C#) - 迭代器模式(Iterator Pattern)

作者:webabcd





介绍

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





示例

有一个Message实体类,某聚合对象内的各个元素均为该实体对象,现在要提供一种方法顺序地访问这个聚合对象中的各个元素。







MessageModel

using System;

using System.Collections.Generic;

using System.Text;



namespace Pattern.Iterator

{

    /**//// <summary>

    /// Message实体类

    /// </summary>

    public class MessageModel

    {

        /**//// <summary>

        /// 构造函数

        /// </summary>

        /// <param name="msg">Message内容</param>

        /// <param name="pt">Message发布时间</param>

        public MessageModel(string msg, DateTime pt)

        {

            this._message = msg;

            this._publishTime = pt;

        }



        private string _message;

        /**//// <summary>

        /// Message内容

        /// </summary>

        public string Message

        {

            get { return _message; }

            set { _message = value; }

        }



        private DateTime _publishTime;

        /**//// <summary>

        /// Message发布时间

        /// </summary>

        public DateTime PublishTime

        {

            get { return _publishTime; }

            set { _publishTime = value; }

        }

    }

}

ICollection

using System;

using System.Collections.Generic;

using System.Text;



namespace Pattern.Iterator

{

    /**//// <summary>

    /// 集合接口(Aggregate)

    /// </summary>

    public interface ICollection

    {

        /**//// <summary>

        /// 创建迭代器对象

        /// </summary>

        /// <returns></returns>

        IIterator CreateIterator();

    }

}

Collection

using System;

using System.Collections.Generic;

using System.Text;



namespace Pattern.Iterator

{

    /**//// <summary>

    /// 集合(ConcreteAggregate)

    /// </summary>

    public class Collection : ICollection

    {

        private List<MessageModel> list = new List<MessageModel>();



        /**//// <summary>

        /// 创建迭代器对象

        /// </summary>

        /// <returns></returns>

        public IIterator CreateIterator()

        {

            return new Iterator(this);

        }



        /**//// <summary>

        /// 集合内的对象总数

        /// </summary>

        public int Count

        {

            get { return list.Count; }

        }



        /**//// <summary>

        /// 索引器

        /// </summary>

        /// <param name="index">index</param>

        /// <returns></returns>

        public MessageModel this[int index]

        {

            get { return list[index]; }

            set { list.Add(value); }

        }



    }

}

IIterator

using System;

using System.Collections.Generic;

using System.Text;



namespace Pattern.Iterator

{

    /**//// <summary>

    /// 迭代器接口(IIterator)

    /// </summary>

    public interface IIterator

    {

        /**//// <summary>

        /// 第一个对象

        /// </summary>

        /// <returns></returns>

        MessageModel First();



        /**//// <summary>

        /// 下一个对象

        /// </summary>

        /// <returns></returns>

        MessageModel Next();



        /**//// <summary>

        /// 当前对象

        /// </summary>

        MessageModel CurrentMessageModel { get; }



        /**//// <summary>

        /// 是否迭代完毕

        /// </summary>

        bool IsDone { get; }

    }

}

Iterator

using System;

using System.Collections.Generic;

using System.Text;



namespace Pattern.Iterator

{

    /**//// <summary>

    /// 迭代器(Iterator)

    /// </summary>

    public class Iterator : IIterator

    {

        private Collection _collection;

        ;

        ;



        /**//// <summary>

        /// 构造函数

        /// </summary>

        /// <param name="collection"></param>

        public Iterator(Collection collection)

        {

            this._collection = collection;

        }



        /**//// <summary>

        /// 第一个对象

        /// </summary>

        /// <returns></returns>

        public MessageModel First()

        {

            _current ;

            return _collection[_current];

        }



        /**//// <summary>

        /// 下一个对象

        /// </summary>

        /// <returns></returns>

        public MessageModel Next()

        {

            _current += _step;



            if (!IsDone)

            {

                return _collection[_current];

            }

            else

            {

                return null;

            }

        }



        /**//// <summary>

        /// 当前对象

        /// </summary>

        public MessageModel CurrentMessageModel

        {

            get { return _collection[_current]; }

        }



        /**//// <summary>

        /// 是否迭代完毕

        /// </summary>

        public bool IsDone

        {

            get { return _current >= _collection.Count ? true : false; }

        }



        /**//// <summary>

        /// 步长

        /// </summary>

        public int Step

        {

            get { return _step; }

            set { _step = value; }

        }

    }

}

Test

using System;

using System.Data;

using System.Configuration;

using System.Collections;

using System.Web;

using System.Web.Security;

using System.Web.UI;

using System.Web.UI.WebControls;

using System.Web.UI.WebControls.WebParts;

using System.Web.UI.HtmlControls;



using I = Pattern.Iterator;



public partial class Iterator : System.Web.UI.Page

{

    protected void Page_Load(object sender, EventArgs e)

    {

        I::Collection collection = new I::Collection();



        collection[] = new I::MessageModel("第1条信息", DateTime.Now);

        collection[] = new I::MessageModel("第2条信息", DateTime.Now);

        collection[] = new I::MessageModel("第3条信息", DateTime.Now);

        collection[] = new I::MessageModel("第4条信息", DateTime.Now);

        collection[] = new I::MessageModel("第5条信息", DateTime.Now);

        collection[] = new I::MessageModel("第6条信息", DateTime.Now);

        collection[] = new I::MessageModel("第7条信息", DateTime.Now);

        collection[] = new I::MessageModel("第8条信息", DateTime.Now);

        collection[] = new I::MessageModel("第9条信息", DateTime.Now);



        I::Iterator iterator = new I::Iterator(collection);



        iterator.Step ;



        for (I::MessageModel mm = iterator.First(); !iterator.IsDone; mm = iterator.Next())

        {

            Response.Write(mm.Message);

            Response.Write("<br />");

        }

    }

}

运行结果

第1条信息

第3条信息

第5条信息

第7条信息

第9条信息





参考

http://www.dofactory.com/Patterns/PatternIterator.aspx





OK

[源码下载]

乐在其中设计模式(C#) - 迭代器模式(Iterator Pattern)的更多相关文章

  1. 设计模式学习--迭代器模式(Iterator Pattern)和组合模式(Composite Pattern)

    设计模式学习--迭代器模式(Iterator Pattern) 概述 ——————————————————————————————————————————————————— 迭代器模式提供一种方法顺序 ...

  2. 二十四种设计模式:迭代器模式(Iterator Pattern)

    迭代器模式(Iterator Pattern) 介绍提供一种方法顺序访问一个聚合对象中各个元素,而又不需暴露该对象的内部表示. 示例有一个Message实体类,某聚合对象内的各个元素均为该实体对象,现 ...

  3. [设计模式] 16 迭代器模式 Iterator Pattern

    在GOF的<设计模式:可复用面向对象软件的基础>一书中对迭代器模式是这样说的:提供一种方法顺序访问一个聚合对象中各个元素,而又不需要暴露该对象的内部表示. 类图和实例: 迭代器模式由以下角 ...

  4. 设计模式(十):从电影院中认识"迭代器模式"(Iterator Pattern)

    上篇博客我们从醋溜土豆丝与清炒苦瓜中认识了“模板方法模式”,那么在今天这篇博客中我们要从电影院中来认识"迭代器模式"(Iterator Pattern).“迭代器模式”顾名思义就是 ...

  5. 设计模式系列之迭代器模式(Iterator Pattern)——遍历聚合对象中的元素

    模式概述 模式定义 模式结构图 模式伪代码 模式改进 模式应用 模式在JDK中的应用 模式在开源项目中的应用 模式总结 说明:设计模式系列文章是读刘伟所著<设计模式的艺术之道(软件开发人员内功修 ...

  6. 设计模式 - 迭代器模式(iterator pattern) 具体解释

    迭代器模式(iterator pattern) 详细解释 本文地址: http://blog.csdn.net/caroline_wendy 迭代器模式(iterator pattern) : 提供一 ...

  7. 乐在其中设计模式(C#) - 提供者模式(Provider Pattern)

    原文:乐在其中设计模式(C#) - 提供者模式(Provider Pattern) [索引页][源码下载] 乐在其中设计模式(C#) - 提供者模式(Provider Pattern) 作者:weba ...

  8. 乐在其中设计模式(C#) - 访问者模式(Visitor Pattern)

    原文:乐在其中设计模式(C#) - 访问者模式(Visitor Pattern) [索引页][源码下载] 乐在其中设计模式(C#) - 访问者模式(Visitor Pattern) 作者:webabc ...

  9. 乐在其中设计模式(C#) - 策略模式(Strategy Pattern)

    原文:乐在其中设计模式(C#) - 策略模式(Strategy Pattern) [索引页][源码下载] 乐在其中设计模式(C#) - 策略模式(Strategy Pattern) 作者:webabc ...

随机推荐

  1. select下拉菜单反显不可改动,且submit能够提交数据

    首先通过后台funcA()将下拉菜单反显不可改动的数据response到disable.jsp页面,disable.jsp: <script> var data1=${result.obj ...

  2. android新浪分享实例

    新浪分享比较简单,新浪有提供完整的demo. android实现新浪的分享功能,分3种分享情况: 纯文本的,带图片的,图片为本地图片(传入的是图片在手机的地址),第2种带图片的是,网络图片,图片地址为 ...

  3. loj1236(数学)

    传送门:Pairs Forming LCM 题意:题意:问符合 lcm(i,j)=n (1<=i<=j<=n,1<=n<=10^14) 的 (i,j) 有多少对. 分析: ...

  4. CSS实现输入框的高亮效果-------Day50

    又到周末了,这一天天过的真快,明天应该回老家了.不知道会不会有机会进行编写.尽量争取吧,实在不想就这样间断.假设说从前会一天天无聊到爆,那如今自己应该是一天天忙的要死,欠缺了太多东西,那些浪费的时间可 ...

  5. Filter技术+职责链模式

    Filter是一个过滤器,存在Webclient与请求的资源之间.这里的资源能够说是jsp或servlet.它的作用就是在请求达到资源之前,先对请求进行预处理.而且也能够对servlet处理后的res ...

  6. Java 使用AES/CBC/PKCS7Padding 加解密字符串

    介于java 不支持PKCS7Padding,只支持PKCS5Padding 但是PKCS7Padding 和 PKCS5Padding 没有什么区别要实现在java端用PKCS7Padding填充, ...

  7. hdu4489(递推dp)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4489 题意:给一个n,求n个高矮不同的人排成一排使得高.矮依次排列的种数. 详细思路参考:http:/ ...

  8. NYOJ 284 坦克大战 【BFS】+【优先队列】

    坦克大战 时间限制:1000 ms  |  内存限制:65535 KB 难度:3 描写叙述 Many of us had played the game "Battle city" ...

  9. Mac中如何写NTFS的移动硬盘

    Mac中如何写NTFS的移动硬盘 按 照网上的说法,简单的就是购买Paragon NTFS或者Tuxera NTFS之类的收费软件,不想花钱的就用NTFS-3G.作为一个开发人员,既然能够自己解决,当 ...

  10. HDU 3304 Interesting Yang Yui Triangle lucas定理

    输入p n 求杨辉三角的第n+1行不能被p整除的数有多少个 Lucas定理: A.B是非负整数,p是质数.AB写成p进制:A=a[n]a[n-1]...a[0],B=b[n]b[n-1]...b[0] ...