c++设计模式15 --组合模式
今天研究了一下设计模式15 组合模式 本人是菜鸟一枚,所以一开始完全不懂组合究竟是什么意思。先上图一张,树形结构图:
文档说,如果想做出这样的结构,通常考虑组合模式。那是为什么呢?现在让我们看一下组合模式的类图一本结构

想了很久,结合源代码,才搞明白,其实这个组合,意思就是说,如果我们要做这种树状结果,比如公司想让我们吧所有部门人员的 姓名,职位,薪水遍历出来,这个时候怎么办呢?那我们看树状机构图,有叶子结点和枝干结点,2种,但是2种有共性,那就是每个结点都有姓名,职位,薪水。所有叶子结点和枝干结点共同继承结点接口。因为枝干结点本身还有子结点,而且子结点里面,即可能有叶子结点,也可能有枝干结点,二者不是同一个类型啊,怎么解决呢? 因为 二者都继承了共同的基类 所以 对于枝干结点,我们给其添加属性成员 vector<Component*> s,这样S中既可以存放叶子结点,也可以存放枝干结点,这个地方就体现了 1....n 这个意义。同时也解决了一个容器存储不同类型的问题。
我估计我说的大家也不是特别理解,下面上源代码,结合源代码,相信您会明白的。
.zuhepattern.h
#include<string>
#include<iostream>
#include<vector>
using namespace std;
class CCorpNode
{
public:
CCorpNode();
CCorpNode(string _name,string _pos,int _salary);
virtual ~CCorpNode();
virtual string GetInfo();
void setParent(CCorpNode* _pParent);
CCorpNode* GetParent();
virtual bool IsLeaf()=;
private:
string m_name;
string m_position;
int m_salary;
protected:
bool m_isLeaf;
CCorpNode *m_pParent;
};
class CBranchNode:public CCorpNode
{
public:
CBranchNode();
CBranchNode(string name,string pos,int salary);
~CBranchNode();
void add(CCorpNode *pcorpNode);
vector<CCorpNode*> GetSubordinateInfo();
bool IsLeaf();
private:
vector<CCorpNode*> m_subordinateList;
}; class CLeafNode:public CCorpNode
{
public:
CLeafNode();
CLeafNode(string name ,string pos,int salary);
~CLeafNode();
bool IsLeaf();
}; //实现部分
#include "stdafx.h"
#include "zuhepattern.h"
CCorpNode::CCorpNode()
{
this->m_name="";
this->m_position="";
this->m_salary=;
}
CCorpNode::CCorpNode(string _name,string _pos,int _salary):m_name(_name),m_position(_pos),m_salary(_salary)
{ }
CCorpNode::~CCorpNode(){}
string CCorpNode::GetInfo()
{
char ss[];
itoa(this->m_salary,ss,);
string info="";
info=info+"姓名:"+this->m_name;
info=info+"\t职位:"+this->m_position;
info=info+"\t薪水:"+ss;
return info;
}
void CCorpNode::setParent(CCorpNode* _pParent)
{
this->m_pParent=_pParent;
}
CCorpNode* CCorpNode::GetParent()
{
return this->m_pParent;
}
CBranchNode::CBranchNode(){
this->m_isLeaf=false;
}
CBranchNode::CBranchNode(string name, string pos, int salary):CCorpNode(name, pos, salary)
{
this->m_isLeaf=false;
}
CBranchNode::~CBranchNode(){} void CBranchNode::add(CCorpNode* pcorpNode)
{
this->setParent(this);
this->m_subordinateList.push_back(pcorpNode); }
vector<CCorpNode*> CBranchNode::GetSubordinateInfo()
{
return this->m_subordinateList;
}
bool CBranchNode::IsLeaf()
{
return this->m_isLeaf;
}
CLeafNode::CLeafNode()
{
this->m_isLeaf=true;
}
CLeafNode::CLeafNode(string name ,string pos,int salary):CCorpNode(name, pos, salary)
{
this->m_isLeaf=true;
}
CLeafNode::~CLeafNode(){}
bool CLeafNode::IsLeaf()
{
return this->m_isLeaf;
} //main函数部分 #include "stdafx.h"
#include <string>
#include<iostream>
#include "zuhepattern.h"
using namespace std; static CBranchNode compositeCorpTree()
{
//根节点
CBranchNode root("王大麻子","总经理",);
//三个部门经理--树叉
CBranchNode developDep("刘大瘸子","研发部经理",);
CBranchNode saleDep("马二拐子","销售部门经理",);
CBranchNode financeDep("赵三驼子","研发部经理",); CBranchNode fistDevGroup("杨三","开发一组长",);
CBranchNode secondDevGroup("李四","开发二组长",); //叶子结点
CLeafNode a("a","开发人员",);
CLeafNode b("b","开发人员",);
CLeafNode c("c","开发人员",);
CLeafNode d("d","开发人员",);
CLeafNode e("e","开发人员",);
CLeafNode f("f","开发人员",);
CLeafNode g("g","开发人员",);
CLeafNode h("h","销售人员",);
CLeafNode i("i","销售人员",);
CLeafNode j("j","财务人员",);
CLeafNode k("k","ceo秘书",);
CLeafNode zhenglaoliu("郑老六","研发部副经理",); //开始组装
//CEO下有三个部门经理和一个秘书 root.add(&k);
root.add(&developDep);
root.add(&saleDep);
root.add(&financeDep);
//研发部经理
developDep.add(&zhenglaoliu);
developDep.add(&fistDevGroup);
developDep.add(&secondDevGroup); //开发组成员 fistDevGroup.add(&a);
fistDevGroup.add(&b);
fistDevGroup.add(&c);
secondDevGroup.add(&d);
secondDevGroup.add(&e); secondDevGroup.add(&f);
secondDevGroup.add(&g);
secondDevGroup.add(&a); //销售部人员
saleDep.add(&h);
saleDep.add(&i); //最后一个财务
financeDep.add(&j);
return root;
} static string getTreeInfo(CBranchNode root)
{
vector<CCorpNode*> subordinatelist=root.GetSubordinateInfo();
string info="";
for(vector<CCorpNode*>::iterator ts=subordinatelist.begin();ts!=subordinatelist.end();++ts)
{
if((*ts)->IsLeaf())
{
info=info+(*ts)->GetInfo()+"\n";
}else
{
info=info+(*ts)->GetInfo()+"\n"+getTreeInfo(*((CBranchNode*)*ts)); //基类对象是无法转为子类对象的,所以要先由基类指针转为子类指针,再转为子类对象。
}
}
return info;
} int main(int argc, _TCHAR* argv[])
{ CBranchNode ceo=compositeCorpTree();
cout<<ceo.GetInfo()<<endl;
cout<<getTreeInfo(ceo)<<endl;
int i=;
cin>>i;
return ;
}
c++设计模式15 --组合模式的更多相关文章
- 再起航,我的学习笔记之JavaScript设计模式15(组合模式)
		
组合模式 组合模式(Composite): 又称部分-整体模式,将对象组合成树形结构以表示"部分整体"的层次结构.组合模式使得用户对单个对象和组合对象的使用具有一致性. 如果有一个 ...
 - C#设计模式(10)——组合模式(Composite Pattern)
		
一.引言 在软件开发过程中,我们经常会遇到处理简单对象和复合对象的情况,例如对操作系统中目录的处理就是这样的一个例子,因为目录可以包括单独的文件,也可以包括文件夹,文件夹又是由文件组成的,由于简单对象 ...
 - 乐在其中设计模式(C#) - 组合模式(Composite Pattern)
		
原文:乐在其中设计模式(C#) - 组合模式(Composite Pattern) [索引页][源码下载] 乐在其中设计模式(C#) - 组合模式(Composite Pattern) 作者:weba ...
 - JavaScript设计模式之----组合模式
		
javascript设计模式之组合模式 介绍 组合模式是一种专门为创建Web上的动态用户界面而量身制定的模式.使用这种模式可以用一条命令在多个对象上激发复杂的或递归的行为.这可以简化粘合性代码,使其更 ...
 - C#设计模式(10)——组合模式(Composite Pattern)(转)
		
一.引言 在软件开发过程中,我们经常会遇到处理简单对象和复合对象的情况,例如对操作系统中目录的处理就是这样的一个例子,因为目录可以包括单独的文件,也可以包括文件夹,文件夹又是由文件组成的,由于简单对象 ...
 - C#设计模式:组合模式(Composite Pattern)
		
一,C#设计模式:组合模式(Composite Pattern) using System; using System.Collections.Generic; using System.Linq; ...
 - 【GOF23设计模式】组合模式
		
来源:http://www.bjsxt.com/ 一.[GOF23设计模式]_组合模式.树状结构.杀毒软件架构.JUnite底层架构.常见开发场景 package com.test.composite ...
 - iOS设计模式之组合模式
		
组合模式(Composite) 基本理解 整体和部分可以一直对待. 组合模式:将对象组合成树形结构以表示"部分--整体"的层次结构.组合模式使得用户对单个对象和组合独享的使用具有一 ...
 - 设计模式:组合模式(Composite)
		
定 义:将对象组合树形结构以表示“部分-整体”的层次结构.组合模式使得用户对单个对象和组合对象使用具有一致性. 结构图: Component类: abstract class Component ...
 
随机推荐
- MapReduce整体架构分析
			
继前段时间分析Redis源代码一段时间之后.我即将開始接下来的一段技术学习的征程.研究的技术就是当前很火热的Hadoop,可是一个Hadoop生态圈是很庞大的.所以首先我的打算是挑选当中的一部分模块, ...
 - css3圆角代码
			
div+css3普通圆角代码示例 <style type="text/css"> #round { width:200px; height:100px; margin: ...
 - 【ASP.NET Web API教程】2.4 创建Web API的帮助页面
			
原文:[ASP.NET Web API教程]2.4 创建Web API的帮助页面 注:本文是[ASP.NET Web API系列教程]的一部分,如果您是第一次看本博客文章,请先看前面的内容. 2.4 ...
 - Boost Thread学习笔记五
			
多线程编程中还有一个重要的概念:Thread Local Store(TLS,线程局部存储),在boost中,TLS也被称作TSS,Thread Specific Storage.boost::thr ...
 - asp.net mvc 导出表格
			
适合使用的场合: .net 中从前台中的table导出成excel文件,兼容各种浏览器. 使用工具: org.in2bits.MyXls.dll 从前台获取表格的thead和表格的tbody,将其转化 ...
 - Mac OS设置rootpassword
			
不知怎么忘记mac os系统的rootpassword了 方法一: 首先,启动机器,启动时按住Apple和S键,以单用户模式(single user mode)进入系统.输入:mount -uw / ...
 - 与众不同 windows phone (4) - Launcher(启动器)
			
原文:与众不同 windows phone (4) - Launcher(启动器) [索引页][源码下载] 与众不同 windows phone (4) - Launcher(启动器) 作者:weba ...
 - Maven-1:下载&安装
			
(一)下载 下载网址:http://maven.apache.org/download.cgi 版本:3.0.5 (二)安装 1.解压至目录:F:\Kevin\software\apache-mave ...
 - JQuery 事件与动画
			
第一大部分 提纲 事件与动画 一.事件 1.在JavaScript语法中的事件,把onxxxxx中的on去掉,就是JQuery中的事件. onclick - click ondblclick - db ...
 - Thinkphp学习04
			
原文:Thinkphp学习04 一.ThinkPHP 3 的输出 (重点) a.通过 echo 等PHP原生的输出方式在页面中输出 b.通过display方法输出 想分配变量可以使用as ...