一. 举例

这个例子是书上的,假设有一个公司的组结结构如下:

它的结构很像一棵树,其中人力资源部和财务部是没有子结点的,具体公司才有子结点。

而且最关健的是,它的每一层结构很相似。

代码实现如下:

  1. //公司类,提供接口
  2. class Company
  3. {
  4. public:
  5. Company(string name)
  6. {
  7. m_name = name;
  8. }
  9. virtual ~Company()
  10. {}
  11. virtual void Add(Company *pCom)
  12. {}
  13. virtual void Display(int depth)
  14. {}
  15. protected:
  16. string m_name;
  17. };
  18. //具体公司
  19. class ConcreteCompany : public Company
  20. {
  21. public:
  22. ConcreteCompany(string name): Company(name)
  23. {}
  24. virtual ~ConcreteCompany()
  25. {}
  26. //增加子树或叶子
  27. void Add(Company *pCom)
  28. {
  29. m_listCompany.push_back(pCom);
  30. }
  31. //显示
  32. void Display(int depth)
  33. {
  34. for(int i = 0;i < depth; i++)
  35. {
  36. cout<<"-";
  37. }
  38. cout<< m_name << endl;
  39. list<Company *>::iterator iter = m_listCompany.begin();
  40. for(; iter != m_listCompany.end(); iter++) //显示下层结点
  41. {
  42. (*iter)->Display(depth + 2);
  43. }
  44. }
  45. private:
  46. list<Company *> m_listCompany;
  47. };
  48. //具体的部门,财务部
  49. class FinanceDepartment : public Company
  50. {
  51. public:
  52. FinanceDepartment(string name):Company(name)
  53. {}
  54. virtual ~FinanceDepartment()
  55. {}
  56. //只需显示,无限添加函数,因为已是叶结点
  57. virtual void Display(int depth)
  58. {
  59. for(int i = 0; i < depth; i++)
  60. cout<<"-";
  61. cout<< m_name << endl;
  62. }
  63. };
  64. //具体的部门,人力资源部
  65. class HRDepartment :public Company
  66. {
  67. public:
  68. HRDepartment(string name):Company(name)
  69. {}
  70. virtual ~HRDepartment()
  71. {}
  72. //只需显示,无限添加函数,因为已是叶结点
  73. virtual void Display(int depth)
  74. {
  75. for(int i = 0; i < depth; i++)
  76. {
  77. cout<<"-";
  78. }
  79. cout<< m_name << endl;
  80. }
  81. };
  82. //////////////////////////////////////////////////////////////////////////
  83. //测试代码
  84. int main()
  85. {
  86. Company *root = new ConcreteCompany("总公司");
  87. Company *leaf1=new FinanceDepartment("财务部");
  88. Company *leaf2=new HRDepartment("人力资源部");
  89. root->Add(leaf1);
  90. root->Add(leaf2);
  91. //华东分公司
  92. Company *mid1 = new ConcreteCompany("华东分公司");
  93. Company *leaf3=new FinanceDepartment("华东分公司财务部");
  94. Company *leaf4=new HRDepartment("华东分公司人力资源部");
  95. mid1->Add(leaf3);
  96. mid1->Add(leaf4);
  97. root->Add(mid1);
  98. //南京办事处
  99. Company *mid2=new ConcreteCompany("南京办事处");
  100. FinanceDepartment *leaf5=new FinanceDepartment("南京办事处财务部");
  101. HRDepartment *leaf6=new HRDepartment("南京办事处人力资源部");
  102. mid2->Add(leaf5);
  103. mid2->Add(leaf6);
  104. root->Add(mid2);
  105. //杭州办事处
  106. Company *mid3=new ConcreteCompany("杭州办事处");
  107. FinanceDepartment *leaf7=new FinanceDepartment("杭州办事处财务部");
  108. HRDepartment *leaf8=new HRDepartment("杭州办事处人力资源部");
  109. mid3->Add(leaf7);
  110. mid3->Add(leaf8);
  111. mid2->Add(mid3);
  112. root->Display(0);
  113. delete leaf1;
  114. delete leaf2;
  115. delete leaf3;
  116. delete leaf4;
  117. delete leaf5;
  118. delete leaf6;
  119. delete leaf7;
  120. delete leaf8;
  121. delete mid1;
  122. delete mid2;
  123. delete root;
  124. return 0;
  125. }

二. 说明

1. 上面公司的结构图其实就是整体与部分的关系,而且的话整体与部分可以一致对待,因为有很多相似之处嘛。

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

其实这种模式就是组合模式。

三. 组合模式

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

要注意两点:

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

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

结构图如下:

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

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

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

设计模式C++描述----11.组合(Composite)模式的更多相关文章

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

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

  2. Ruby设计模式透析之 —— 组合(Composite)

    转载请注明出处:http://blog.csdn.net/sinyu890807/article/details/9153761 此为Java设计模式透析的拷贝版,专门为Ruby爱好者提供的,不熟悉R ...

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

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

  4. 设计模式之第11章-建造者模式(Java实现)

    设计模式之第11章-建造者模式(Java实现) “那个餐厅我也是醉了...”“怎么了?”“上菜顺序啊,竟然先上甜品,然后是冷饮,再然后才是菜什么的,无语死了.”“这个顺序也有人这么点的啊.不过很少就是 ...

  5. 《图解设计模式》读书笔记5-1 composite模式

    目录 代码 角色 想法 Composite模式即组合模式.它能够使容器和内容具有一致性,创造出递归结构. 举个例子:在文件系统中,文件夹既是内容,也是容器,具有一致性,这样一来,文件系统形成递归结构. ...

  6. C++设计模式实现--组合(Composite)模式

    一. 举例 这个样例是书上的,如果有一个公司的组结结构例如以下: 它的结构非常像一棵树,当中人力资源部和財务部是没有子结点的,详细公司才有子结点. 并且最关健的是,它的每一层结构非常相似. 代码实现例 ...

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

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

  8. 组合(composite)模式

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

  9. 设计模式C++描述----09.桥接(Bridge)模式

    一. 举例 N年前: 计算机最先出来时,软件和硬件是一绑在一起的,比如IBM出了一台电脑,上面有一个定制的系统,假如叫 IBM_Win,这个IBM_Win系统当然不能在HP电脑上运行,同样HP出的HP ...

随机推荐

  1. Janus安装教程,ubuntu18.04系统

    Janus安装教程,ubuntu18.04系统     本文介绍Jansu如何安装,操作系统为Ubuntu 18.04.    (1)安装git 执行命令:“sudo apt-get install ...

  2. 使用Hugo,只需5分钟,轻松搭建一个自己的博客

    前面跟大家介绍过hexo这款静态博客系统,功能强大,基本能满足博客的各种需求.今天,我再跟大家介绍一款优秀的静态博客系统,那就是Hugo. Hugo是由Go语言实现的静态网站生成器.简单.易用.高效. ...

  3. Angular 内嵌视图、宿主视图

    解析视图: 内嵌视图 - 连接到模板的嵌入视图,在组件模板元素中添加模板(DOM元素.DOM元素组) 宿主视图 - 连接到组件的嵌入视图,在组件元素中添加别的组件 使用类说明: ElementRef ...

  4. IDEA 导入 Maven 项目后报错 cannot resolve symbol 解决办法

    这两天整理项目,导入新的 Maven 项目时出现 cannot resolve symbol ,即使 rebuild 也没有用.解决办法如下: 1. File -> Close Project: ...

  5. 03-body标签中的部分标签

    一.字体标签 标题标签h1-h6 h1定义最大的标题,h6定义最小的标题,一般一个页面中h1只能出现一次,尽量标题不要超过三级.h标签具有align属性,属性值分别是:left.center.righ ...

  6. .NET进阶篇-丑话先说,Flag先立

    作为开发者,工作了几年,也总觉得技术栈和刚毕业区别不大,用的技术还都是N年前的,每每看到新东西,也只心里哇塞惊叹一下,然后就回归于忙碌.怪自己的技术池太浅,热门的令人称奇的技术也都是在其他巨人的肩膀上 ...

  7. Linux——基本命令

    目录 一.目录切换命令 二.目录操作命令(增删改查) 2.1增加目录 2.2查看目录 2.3寻找目录(搜索) 2.4修改目录名称 2.5移动目录位置(剪切) 2.6拷贝目录 2.7删除目录 三.文件的 ...

  8. PHP 微信机器人 Vbot 结合 Laravel 基础入门及实例

    新来了项目,需要能监听指定微信群的消息并进行转发.基于 PHP 7 的 web 微信机器人 Vbot 可以满足需求.Vbot 本质上就是实现了登录网页版微信来进行自动回复.群管理等等操作. githu ...

  9. el-table实现行列拖拽

    element ui 表格没有自带的拖拽排序的功能,只能借助第三方插件Sortablejs来实现. 实现步骤: 安装Sortable.js npm install sortablejs --save ...

  10. .netCore+Vue 搭建的简捷开发框架 (4)--NetCore 基础 -2

    上节中,我们初步的介绍了一下NetCore的一些基础知识,为了控制篇幅(其实也是因为偷懒),我将NetCore 基础分为两部分来写. 0.WebAPI 项目的建立 1..NetCore 项目执行(加载 ...