一. 举例

这个样例是书上的,如果有一个公司的组结结构例如以下:

它的结构非常像一棵树,当中人力资源部和財务部是没有子结点的,详细公司才有子结点。

并且最关健的是,它的每一层结构非常相似。

代码实现例如以下:

#include <iostream>

#include <list>

#include <string>

using namespace std;





//公司类,提供接口  

class Company      

{    

public:    

Company(string name)  

{  

m_name = name;  

}    





virtual ~Company()  

{}    





virtual void Add(Company *pCom)  

{}    





virtual void Display(int depth)  

{}  





protected:  

string m_name;    

};  





//详细公司  

class ConcreteCompany : public Company      

{    

public:    

ConcreteCompany(string name): Company(name)  

{}  





virtual ~ConcreteCompany()  

{}  





//添加�子树或叶子  

void Add(Company *pCom)  

{  

m_listCompany.push_back(pCom);  

}  





//显示  

void Display(int depth)  

{  

for(int i = 0;i < depth; i++)  

{  

cout<<"-";    





}  





cout<< m_name << endl;  





list<Company *>::iterator iter = m_listCompany.begin();    





for(; iter != m_listCompany.end(); iter++) //显示下层结点    

{      

(*iter)->Display(depth + 2);  

}  

}  





private:    

list<Company *> m_listCompany;    

};    





//详细的部门,財务部    

class FinanceDepartment : public Company     

{  

public:    

FinanceDepartment(string name):Company(name)  

{}    





virtual ~FinanceDepartment()  

{}    





//仅仅需显示,无限加入�函数,由于已是叶结点    

virtual void Display(int depth)  

{    

for(int i = 0; i < depth; i++)    

cout<<"-";    





cout<< m_name << endl;  

}  

};    





//详细的部门,人力资源部    

class HRDepartment :public Company      

{    

public:    

HRDepartment(string name):Company(name)  

{}  





virtual ~HRDepartment()  

{}  





//仅仅需显示,无限加入�函数,由于已是叶结点    

virtual void Display(int depth)  

{  

for(int i = 0; i < depth; i++)    

{  

cout<<"-";  

}  

cout<< m_name << endl;    

}    

};  





//////////////////////////////////////////////////////////////////////////  

//測试代码  

int main()  

{  

Company *root = new ConcreteCompany("总公司");    

Company *leaf1=new FinanceDepartment("財务部");    

Company *leaf2=new HRDepartment("人力资源部");    

root->Add(leaf1);    

root->Add(leaf2);    





//华东分公司  

Company *mid1 = new ConcreteCompany("华东分公司");    

Company *leaf3=new FinanceDepartment("华东分公司財务部");    

Company *leaf4=new HRDepartment("华东分公司人力资源部");    

mid1->Add(leaf3);  

mid1->Add(leaf4);  

root->Add(mid1);  





//南京办事处  

Company *mid2=new ConcreteCompany("南京办事处");    

FinanceDepartment *leaf5=new FinanceDepartment("南京办事处財务部");    

HRDepartment *leaf6=new HRDepartment("南京办事处人力资源部");    

mid2->Add(leaf5);  

mid2->Add(leaf6);  

root->Add(mid2);  





//杭州办事处  

Company *mid3=new ConcreteCompany("杭州办事处");    

FinanceDepartment *leaf7=new FinanceDepartment("杭州办事处財务部");    

HRDepartment *leaf8=new HRDepartment("杭州办事处人力资源部");    

mid3->Add(leaf7);    

mid3->Add(leaf8);    

mid2->Add(mid3);  





root->Display(0);  





delete leaf1;  

delete leaf2;    

delete leaf3;  

delete leaf4;    

delete leaf5;  

delete leaf6;  

delete leaf7;  

delete leaf8;    

delete mid1;  

delete mid2;    

delete root;    

getchar();

return 0;  

}  

二. 说明

1. 上面公司的结构图事实上就是总体与部分的关系,并且的话总体与部分能够一致对待,由于有非常多相似之处嘛。

2. 这棵树有两种几能,要么是棵叶,要么是子棵。

事实上这样的模式就是组合模式。

三. 组合模式

定义:将对象组合成树形结构以表示“部分-总体”的层次结构。组合使得用户对单个对象和组合对象的使用具有一致性

要注意两点:

1. “树形”,必须是一种层次结构,有能够向下延伸的分枝,也有不变的树叶。

2. "一致性",也就是要具有非常多相似性。

结构图例如以下:

component:主要是定义统一的接口,说白了也就是提取出相似性。

composite:定义分枝节点,也就是子树。

leaf:定义叶节点,叶节点是没有子节点的。

C++设计模式实现--组合(Composite)模式的更多相关文章

  1. Head First 设计模式 —— 11. 组合 (Composite) 模式

    思考题 我们不仅仅要支持多个菜单,升值还要支持菜单中的菜单.你如何处理这个新的设计需求? P355 [提示]在我们的新设计中,真正需要以下三点: P354 我们需要某种属性结构,可以容纳菜单.子菜单和 ...

  2. Java 实现组合(Composite)模式

    类图 /** * 树 总体 * * @author stone * */ public class Tree { private TreeNode root; //根节点 public Tree(St ...

  3. 设计模式C++描述----11.组合(Composite)模式

    一. 举例 这个例子是书上的,假设有一个公司的组结结构如下: 它的结构很像一棵树,其中人力资源部和财务部是没有子结点的,具体公司才有子结点. 而且最关健的是,它的每一层结构很相似. 代码实现如下: / ...

  4. 组合(composite)模式

    定义 将对象组合成树形结构以表示“部分-整体”的层次结构,使得用户对单个对象和组合对象的使用具有一致性 组合模式(Composite)将小对象组合成树形结构,使用户操作组合对象如同操作一个单个对象.组 ...

  5. 八、结构模式之组合(Composite)模式

    组合模式属于对象的结构模式,有时又叫做部分-整体模式,组合模式将对象组织到树结构中,可以用来描述整体与部分的联系.其可以使客户端将单纯元素和组合元素同等对待. 当需求中是体现部分与整体层次的结构时,以 ...

  6. Java设计模式之 — 组合(Composite)

    转载请注明出处:http://blog.csdn.net/guolin_blog/article/details/9153753 听说你们公司最近新推出了一款电子书阅读应用,市场反应很不错,应用里还有 ...

  7. C#设计模式(10)——组合模式(Composite Pattern)

    一.引言 在软件开发过程中,我们经常会遇到处理简单对象和复合对象的情况,例如对操作系统中目录的处理就是这样的一个例子,因为目录可以包括单独的文件,也可以包括文件夹,文件夹又是由文件组成的,由于简单对象 ...

  8. [设计模式] 8 组合模式 Composite

    DP书上给出的定义:将对象组合成树形结构以表示“部分-整体”的层次结构.组合使得用户对单个对象和组合对象的使用具有一致性.注意两个字“树形”.这种树形结构在现实生活中随处可见,比如一个集团公司,它有一 ...

  9. 乐在其中设计模式(C#) - 组合模式(Composite Pattern)

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

随机推荐

  1. Maven手动创建多模块项目

    Maven手动创建多模块项目 我要创建的项目名称是:unicorn,项目包含两个模块,分别是unicorn-core和unicorn-web.包的路径是com.goldpalm.tour. 项目创建流 ...

  2. Ie浏览器TextBox文本未居中

    Ie浏览器TextBox文本未居中,而其他浏览器无问题时,可能原因是未设置垂直居中  vertical-align:middle

  3. 几篇SIEM文章

    http://infosecnirvana.com/tag/siem-rule-types/ http://www.tripwire.com/state-of-security/security-da ...

  4. java.lang.RuntimeException: Unable to start activity ComponentInfo

    异常:java.lang.RuntimeException: Unable to start activity ComponentInfo{com.william/com.william.Result ...

  5. 清理8组nodes中表的历史数据,平均每个node中的表有1.5亿条记录,需要根据date_created字段清理8000W数据记录,这个字段没有索引。

    清理8组nodes中表的历史数据,平均每个node中的表有1.5亿条记录,需要根据date_created字段清理8000W数据记录,这个字段没有索引. 环境介绍  线上磁盘空间不足,truncate ...

  6. USACO chapter1

    几天时间就把USACO chapter1重新做了一遍,发现了自己以前许多的不足.蒽,现在的程序明显比以前干净很多,而且效率也提高了许多.继续努力吧,好好的提高自己.这一章主要还是基本功的训练,没多少的 ...

  7. node.weiChat

    微信的朋友圈分享是现在流行的推广模式,最近两天尝试了一下使用微信进行商品的分享,分享结束后我可以在自己的数据库中查询到用户是否分享成功,包括用户使用微信进行支付时的成功验证.个人觉得微信上的教程有些绕 ...

  8. linux杂谈(十七):iscsi存储分离技术

    1.iscsi简单介绍 ​ ​iSCSI利用了TCP/IP的port 860 和 3260 作为沟通的渠道.透过两部计算机之间利用iSCSI的协议来交换SCSI命令,让计算机能够透过快速的局域网集线来 ...

  9. 通过jstack定位在线执行java系统故障_案例1

    问题描写叙述: 在一个在线执行的java web系统中,会定时执行一个FTP上传的任务,结果有一天发现,文件正常生成后却没有上传. 问题初步分析: 1.查看日志文件 发现这个任务仅仅打印了開始进入FT ...

  10. iOS开发-Protocol协议及委托代理(Delegate)传值

    前言:因为Object-C是不支持多继承的,所以很多时候都是用Protocol(协议)来代替.Protocol(协议)只能定义公用的一套接口,但不能提供具体的实现方法.也就是说,它只告诉你要做什么,但 ...