会员: 密码:  免费注册 | 忘记密码 | 会员登录 网页功能: 加入收藏 设为首页 网站搜索  
 安全技术技术文档
  · 安全配制
  · 工具介绍
  · 黑客教学
  · 防火墙
  · 漏洞分析
  · 破解专题
  · 黑客编程
  · 入侵检测
 安全技术论坛
  · 安全配制
  · 工具介绍
  · 防火墙
  · 黑客入侵
  · 漏洞检测
  · 破解方法
  · 杀毒专区
 安全技术工具下载
  · 扫描工具
  · 攻击程序
  · 后门木马
  · 拒绝服务
  · 口令破解
  · 代理程序
  · 防火墙
  · 加密解密
  · 入侵检测
  · 攻防演示
技术文档 > JAVA
足球战术之iterator篇
发表日期:2004-07-30 18:08:05作者: 出处:  


 

接上回:

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 _当前;
};


 

返回顶部】 【打印本页】 【关闭窗口

关于我们 / 给我留言 / 版权举报 / 意见建议 / 网站编程QQ群   
Copyright ©2003- 2024 Lihuasoft.net webmaster(at)lihuasoft.net 加载时间 0.00129