Java

本类阅读TOP10

·使用MyEclipse开发Struts框架的Hello World!(录像1)
·hibernate配置笔记
·AOP编程入门--Java篇
·linux下Tomcat 5.0.20 与 Apache 2 安装/集成/配置
·在win2003下整合了整合Tomcat5.5+ apache_2.0.53+ mod_jk_2.0.47.dll
·构建Linux下IDE环境--Eclipse篇
·Jsp 连接 mySQL、Oracle 数据库备忘(Windows平台)
·ASP、JSP、PHP 三种技术比较
·Tomcat5.5.9的安装配置
·AWT GUI 设计笔记(二)

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
足球战术之iterator篇

作者:未知 来源:月光软件站 加入时间:2005-2-28 月光软件站

接上回:

http://www.csdn.net/develop/read_article.asp?id=11677

使用iterator模式,让每个队员做
iterator,每个位置做aggregate,
有如下几个好处:
1.每个位置支持不同的队员用不同方式遍历。
2.简化了每个位置的接口,使其kiss,不用具有遍历的接口。
3.在同一个位置支持多个队员同时遍历。
代码如下:
template <class Item>
class 位置{
public:
     位置(long size=缺省_位置_容量);
     long 计数() const;
     Item& Get(long index) const;
     //...
};

template <class Item>
class 队员{
public:
     virtual void 回到初始位置()=0;
     virtual void 下一个位置()=0;
     virtual bool 是否到达() const=0;
     virtual Item 当前Item() const=0;
protected:
     队员();
};

template <class Item>
class 左后卫:public 队员<Item>{
public:
     左后卫(const 位置<Item>* 一个位置);
     virtual void 回到初始位置;
     virtual void 下一个位置();
     virtual bool 是否到达() const;
     virtual Item 当前Item() const;
private:
     const 位置<Item>* _位置;
     long _当前;
};




相关文章

相关软件