2022年设计模式C++实现——享元模式参考 .pdf

上传人:H****o 文档编号:40344911 上传时间:2022-09-09 格式:PDF 页数:6 大小:135.70KB
返回 下载 相关 举报
2022年设计模式C++实现——享元模式参考 .pdf_第1页
第1页 / 共6页
2022年设计模式C++实现——享元模式参考 .pdf_第2页
第2页 / 共6页
点击查看更多>>
资源描述

《2022年设计模式C++实现——享元模式参考 .pdf》由会员分享,可在线阅读,更多相关《2022年设计模式C++实现——享元模式参考 .pdf(6页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、设计模式 C+实现(9)享元模式分类:设计模式 2011-08-08 19:43 5565人阅读 评论(37)收藏 举报软件领域中的设计模式为开发人员提供了一种使用专家设计经验的有效途径。设计模式中运用了面向对象编程语言的重要特性:封装、继承、多态,真正领悟设计模式的精髓是可能一个漫长的过程,需要大量实践经验的积累。最近看设计模式的书,对于每个模式,用C+写了个小例子,加深一下理解。主要参考 大话设计模式和设计模式:可复用面向对象软件的基础(DP)两本书。本文介绍享元模式的实现。举个围棋的例子,围棋的棋盘共有361 格,即可放 361 个棋子。现在要实现一个围棋程序,该怎么办呢?首先要考虑的是

2、棋子棋盘的实现,可以定义一个棋子的类,成员变量包括棋子的颜色、形状、位置等信息,另外再定义一个棋盘的类,成员变量中有个容器,用于存放棋子的对象。下面给出代码表示:棋子的定义,当然棋子的属性除了颜色和位置,还有其他的,这里略去。这两个属性足以说明问题。cppview plaincopyprint?1./棋子颜色2.enum PieceColor BLACK,WHITE;3./棋子位置4.struct PiecePos 5.6.int x;7.int y;8.PiecePos(int a,int b):x(a),y(b)9.;10./棋子定义11.class Piece 12.13.protect

3、ed:14.PieceColor m_color;/颜色15.PiecePos m_pos;/位置16.public:17.Piece(PieceColor color,PiecePos pos):m_color(color),m_pos(pos)18.Piece()19.virtualvoid Draw()名师资料总结-精品资料欢迎下载-名师精心整理-第 1 页,共 6 页 -20.;21.class BlackPiece:public Piece 22.23.public:24.BlackPiece(PieceColor color,PiecePos pos):Piece(color,po

4、s)25.BlackPiece()26.void Draw()cout 绘制一颗黑棋 endl;27.;28.class WhitePiece:public Piece 29.30.public:31.WhitePiece(PieceColor color,PiecePos pos):Piece(color,pos)32.WhitePiece()33.void Draw()cout 绘制一颗白棋 endl;34.;棋盘的定义:cppview plaincopyprint?1.class PieceBoard 2.3.private:4.vector m_vecPiece;/棋盘上已有的棋子5.

5、string m_blackName;/黑方名称6.string m_whiteName;/白方名称7.public:8.PieceBoard(string black,string white):m_blackName(black),m_whiteName(white)9.PieceBoard()Clear();10.void SetPiece(PieceColor color,PiecePos pos)/一步棋,在棋盘上放一颗棋子11.12.Piece*piece=NULL;13.if(color=BLACK)/黑方下的14.名师资料总结-精品资料欢迎下载-名师精心整理-第 2 页,共 6

6、 页 -15.piece=new BlackPiece(color,pos);/获取一颗黑棋16.coutm_blackName 在位置(pos.x,pos.yDraw();/在棋盘上绘制出棋子18.19.else20.21.piece=new WhitePiece(color,pos);22.coutm_whiteName 在位置(pos.x,pos.yDraw();24.25.m_vecPiece.push_back(piece);/加入容器中26.27.void Clear()/释放内存28.29.int size=m_vecPiece.size();30.for(int i=0;i s

7、ize;i+)31.delete m_vecPiecei;32.33.;客户的使用方式如下:cppview plaincopyprint?1.int main()2.3.PieceBoard pieceBoard(A,B);4.pieceBoard.SetPiece(BLACK,PiecePos(4,4);5.pieceBoard.SetPiece(WHITE,PiecePos(4,16);6.pieceBoard.SetPiece(BLACK,PiecePos(16,4);7.pieceBoard.SetPiece(WHITE,PiecePos(16,16);8.可以发现,棋盘的容器中存放了

8、已下的棋子,而每个棋子包含棋子的所有属性。一盘棋往往需要含上百颗棋子,采用上面这种实现,占用的空间太大了。如何改进呢?用享元模式。其定义为:运用共享技术有效地支持大量细粒度的对象。名师资料总结-精品资料欢迎下载-名师精心整理-第 3 页,共 6 页 -在围棋中,棋子就是大量细粒度的对象。其属性有内在的,比如颜色、形状等,也有外在的,比如在棋盘上的位置。内在的属性是可以共享的,区分在于外在属性。因此,可以这样设计,只需定义两个棋子的对象,一颗黑棋和一颗白棋,这两个对象含棋子的内在属性;棋子的外在属性,即在棋盘上的位置可以提取出来,存放在单独的容器中。相比之前的方案,现在容器中仅仅存放了位置属性,

9、而原来则是棋子对象。显然,现在的方案大大减少了对于空间的需求。关注 PieceBoard的容器,之前是vectorm_vecPiece,现在是vectorm_vecPos。这里是关键。棋子的新定义,只包含内在属性:cppview plaincopyprint?1./棋子颜色2.enum PieceColor BLACK,WHITE;3./棋子位置4.struct PiecePos 5.6.int x;7.int y;8.PiecePos(int a,int b):x(a),y(b)9.;10./棋子定义11.class Piece 12.13.protected:14.PieceColor m

10、_color;/颜色15.public:16.Piece(PieceColor color):m_color(color)17.Piece()18.virtualvoid Draw()19.;20.class BlackPiece:public Piece 21.22.public:23.BlackPiece(PieceColor color):Piece(color)24.BlackPiece()25.void Draw()cout 绘制一颗黑棋 n;名师资料总结-精品资料欢迎下载-名师精心整理-第 4 页,共 6 页 -26.;27.class WhitePiece:public Piec

11、e 28.29.public:30.WhitePiece(PieceColor color):Piece(color)31.WhitePiece()32.void Draw()cout 绘制一颗白棋 n;33.;相应棋盘的定义为:cppview plaincopyprint?1.class PieceBoard 2.3.private:4.vector m_vecPos;/存放棋子的位置5.Piece*m_blackPiece;/黑棋棋子6.Piece*m_whitePiece;/白棋棋子7.string m_blackName;8.string m_whiteName;9.public:10

12、.PieceBoard(string black,string white):m_blackName(black),m_whiteName(white)11.12.m_blackPiece=NULL;13.m_whitePiece=NULL;14.15.PieceBoard()delete m_blackPiece;delete m_whitePiece;16.void SetPiece(PieceColor color,PiecePos pos)17.18.if(color=BLACK)19.20.if(m_blackPiece=NULL)/只有一颗黑棋21.m_blackPiece=new

13、 BlackPiece(color);22.coutm_blackName 在位置(pos.x,pos.yDraw();24.25.else26.27.if(m_whitePiece=NULL)28.m_whitePiece=new WhitePiece(color);29.coutm_whiteName 在位置(pos.x,pos.yDraw();31.32.m_vecPos.push_back(pos);33.34.;客户的使用方式一样,这里不重复给出,现在给出享元模式的UML 图,以围棋为例。棋盘中含两个共享的对象,黑棋子和白棋子,所有棋子的外在属性都存放在单独的容器中。本人享有博客文章的版权,转载请标明出处http:/ 6 页,共 6 页 -

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 技术资料 > 技术总结

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁