设计模式之(八)组合模式(COMPOSITE)
初始印象
在开发中存在很多整体和部分的关系,这个方式最大的体现就是树形结构。组合模式就是为了更好地解决这类业务场景的问题。先看下组合模式的定义:
将对象组合成树形结构以表示“整体—部分”的层次关系。组合模式使得用户对单个对象和组合对象的使用具有一致性。从定义中可以看出来组合二模式主要有两点;
1、整体 - 部分 之间业务结构用树形表示。
2、让组合对象和各个对象的使用具有一致性。
整体和部分的结构在生活中太广泛了,比如国家行政级别 中国 ,***省,**市 。学校管级别、公司管理组织机构等,下面以公司组织机构为例,来看看组合模式。

根据这个公司组织结构的图片,来引进助兴结构的专业名词:总经理称之为 root 根节点,财务经理、技术经理、开发组长称之为 树枝节点(branch),财务专员、秘书称之为 叶子节点(leaf)。
而具体到代码的实现层面就是,组合模式的核心关键就是把这三个对象实现相同的接口,不管是在组件过程,还是后面的遍历,所有的节点都用相同的接口,使得对树形结构的操作更加方便。
接着介绍组合模式的组成元素
- Component:组合部件,为的是给 root、branch、leaf 不同的节点提供统一的接口。
- Composite:复合节点,就是实现 root、branch 的节点,也叫容器节点。
- Leaf : 叶子节点,不能再有下属节点。也叫简单节点。
应用例子
接下来吧上图中例子实现以下,能够更直观了解组合模式
// 相当于是 Component
public abstract class Zhiwei {
protected String name;
protected String position;
protected float salary; public Zhiwei(String name,String position,float salary){
this.name = name;
this.position = position;
this.salary = salary;
} public abstract void addChild(Zhiwei zhiwei); public abstract void removeChild(Zhiwei zhiwei); public abstract void display(String empty); } //相当于是 Composite
public class LingDao extends Zhiwei { private ArrayList<Zhiwei> children = new ArrayList<Zhiwei>(); public LingDao(String name,String position,float salary){
super(name,position,salary);
} @Override
public void addChild(Zhiwei zhiwei) {
// TODO Auto-generated method stub
children.add(zhiwei);
} @Override
public void removeChild(Zhiwei zhiwei) {
// TODO Auto-generated method stub children.remove(zhiwei);
} @Override
public void display(String empty) {
// TODO Auto-generated method stub
System.out.println(empty+"职位:"+this.position+" 姓名:"+this.name+" 薪水:"+this.salary);
for (Zhiwei zhiwei : children) {
zhiwei.display(empty+" ");
} } } //普通职员
public class Leaf extends Zhiwei { public Leaf(String name, String position, float salary) {
super(name, position, salary); // TODO Auto-generated constructor stub
} @Override
public void addChild(Zhiwei zhiwei) {
// TODO Auto-generated method stub
System.out.println("cannot add zhiwei to leaf");
} @Override
public void removeChild(Zhiwei zhiwei) {
// TODO Auto-generated method stub } @Override
public void display(String empty) {
// TODO Auto-generated method stub
System.out.println(empty+"职位:"+this.position+" 姓名:"+this.name+" 薪水:"+this.salary);
}
} //客户端
public class Client {
public static void main(String[] args) {
Zhiwei leader = new LingDao("张无忌","总经理",100000); Zhiwei manager = new LingDao("杨逍", "技术经理", 50000);
Zhiwei managerB = new LingDao("范瑶","财务经理",50000);
Zhiwei managerC = new LingDao("吴劲草","技术组长",20000); Zhiwei Employee = new LingDao("小昭","秘书",8000); Zhiwei EmployeeA = new LingDao("天字门","财务A",5000);
Zhiwei EmployeeX = new LingDao("地字门","财务B",5200);
Zhiwei EmployeeC = new LingDao("风字门","开发A",8800);
Zhiwei EmployeeD = new LingDao("雷字门","开发B",8400); leader.addChild(manager);
leader.addChild(managerB);
leader.addChild(Employee); manager.addChild(managerC);
manager.addChild(EmployeeC); managerC.addChild(EmployeeD); leader.display("");
}
} /********************控制台************************/ - 职位:总经理 姓名:张无忌 薪水:100000.0
- 职位:技术经理 姓名:杨逍 薪水:50000.0
- 职位:技术组长 姓名:吴劲草 薪水:20000.0
- 职位:开发B 职位:雷字门 薪水:8400.0
- 职位:开发A 姓名:风字门 薪水:8800.0
- 职位:财务经理 姓名:范瑶 薪水:50000.0
- 职位:财务A 姓名:风字门 薪水:5000.0
- 职位:财务B 姓名:地字门 薪水:5200.0
- 职位:秘书 姓名:小昭 薪水:8000.0
通过这个例子可以看出来,不同级别的节点通过同一接口在客户端试用是非常方便的,调用的时候不用管他代表的是什么节点。因为能够同一试用。只是在 leaf 级别的节点中,考虑 addChild 、removeChild 给出错误提示即可。
对模式的分析
我们进一步来分析组合模式的应用场景,除了在很明显的树形结构业务中用,在发挥我们的发散能力,应该能够想到,只要拥有父子关系的场景中都是可以用的,比如窗体打开的父子窗口、各种单位的人事制度的组织结构、文件管理系统、软件系统的树形结构导航。
在思考了组合模式的应用场景后,在考虑下组合模式的优势:
1、定义了实现不同层次的对象的统一接口,对象行为更具有一致性。使得客户端调用比较简单。
2、实现了整个业务场景的类层级的所属关系,通过类里面的 list 来实现。
3、类实现更具一般性,使得代码更具有可扩展性。主要表现在新定义的 composite 和 leaf 继承了统一的操作接口,客户端就不用改变。
小结
组合模式应用场景是具有父子结构的场景,典型的就是树形结构。模式的本质就是对不同级别的节点对象引入统一的接口,对不同级别对象调用、操作具有了一致性。
设计模式之(八)组合模式(COMPOSITE)的更多相关文章
- 设计模式系列之组合模式(Composite Pattern)——树形结构的处理
说明:设计模式系列文章是读刘伟所著<设计模式的艺术之道(软件开发人员内功修炼之道)>一书的阅读笔记.个人感觉这本书讲的不错,有兴趣推荐读一读.详细内容也可以看看此书作者的博客https:/ ...
- 设计模式学习心得<组合模式 Composite>
组合模式(Composite Pattern),又叫部分整体模式,是用于把一组相似的对象当作一个单一的对象.组合模式依据树形结构来组合对象,用来表示部分以及整体层次.这种类型的设计模式属于结构型模式, ...
- 《JAVA设计模式》之组合模式(Composite)
在阎宏博士的<JAVA与模式>一书中开头是这样描述合成(Composite)模式的: 合成模式属于对象的结构模式,有时又叫做“部分——整体”模式.合成模式将对象组织到树结构中,可以用来描述 ...
- 设计模式之:组合模式(Composite)
支持原创:http://blog.csdn.net/hguisu/article/details/7530783 设计模式(七)组合模式Composite(结构型) 1. 概述 在数据结构里面,树结构 ...
- 设计模式(七)组合模式Composite(结构型)
设计模式(七)组合模式Composite(结构型) 1. 概述 在数据结构里面,树结构是很重要,我们可以把树的结构应用到设计模式里面. 例子1:就是多级树形菜单. 例子2:文件和文件夹目录 2.问题 ...
- 乐在其中设计模式(C#) - 组合模式(Composite Pattern)
原文:乐在其中设计模式(C#) - 组合模式(Composite Pattern) [索引页][源码下载] 乐在其中设计模式(C#) - 组合模式(Composite Pattern) 作者:weba ...
- 【设计模式】组合模式 Composite Pattern
树形结构是软件行业很常见的一种结构,几乎随处可见, 比如: HTML 页面中的DOM,产品的分类,通常一些应用或网站的菜单,Windows Form 中的控件继承关系,Android中的View继承 ...
- python 设计模式之组合模式Composite Pattern
#引入一 文件夹对我们来说很熟悉,文件夹里面可以包含文件夹,也可以包含文件. 那么文件夹是个容器,文件夹里面的文件夹也是个容器,文件夹里面的文件是对象. 这是一个树形结构 咱们生活工作中常用的一种结构 ...
- 浅谈设计模式--组合模式(Composite Pattern)
组合模式(Composite Pattern) 组合模式,有时候又叫部分-整体结构(part-whole hierarchy),使得用户对单个对象和对一组对象的使用具有一致性.简单来说,就是可以像使用 ...
- 二十四种设计模式:组合模式(Composite Pattern)
组合模式(Composite Pattern) 介绍将对象组合成树形结构以表示"部分-整体"的层次结构.它使得客户对单个对象和复合对象的使用具有一致性.示例有一个Message实体 ...
随机推荐
- Rust语言中的常量,变量,运算符,数据类型
简单练练, 夏天太热. const MAX_POINTS: u32 = 100_100; fn main() { let mut x = 5; let y = 5; let y = y + 1; le ...
- pdfium
https://github.com/SubtleCow/AccessControlListsintheDOM/tree/4673d995e5614bc682cecd22f9b2919b2360273 ...
- luogu P1904 天际线
分析 都知道是从左向右扫描 可是该维护什么,扫描什么? 注意想想怎么输出, 实际上它要的输出就是图形的轮廓,即每个突出块的左上节点的x,y 所以说, 我们可以把扫描线扫进的楼房放入线段树,扫出的楼房删 ...
- 16-numpy笔记-莫烦pandas-4
代码 import pandas as pd import numpy as np dates = pd.date_range('20130101', periods=6) df=pd.DataFra ...
- djangoORM 修改表结构/字段/外键操作
Django支持修改表结构 把max_length=64 改为60 再执行一遍 python manage.py makemigrations python manage.py migrate 如果是 ...
- web框架--XSS攻击和CSRF请求伪造
XSS 跨站脚本攻击(Cross Site Scripting),为不和层叠样式表(Cascading Style Sheets, CSS)的缩写混淆,故将跨站脚本攻击缩写为XSS.恶意攻击者往Web ...
- redixdb 基于redis 协议的实时key-value 存储
redixdb 是一个基于redis 协议搞的一个实时key value 处理的轻量级应用,支持多种后端 存储模型. 以下是一个小版的容器镜像(官方的太大了) dockerfile FROM go ...
- 11/11 <Topological Sort> 207
207. Course Schedule 我们定义二维数组 graph 来表示这个有向图,一维数组 in 来表示每个顶点的入度.我们开始先根据输入来建立这个有向图,并将入度数组也初始化好.然后我们定义 ...
- [LeetCode] 300. Longest Increasing Subsequence 最长递增子序列
Given an unsorted array of integers, find the length of longest increasing subsequence. Example: Inp ...
- 传统的DOM渲染方式
什么是DOM渲染: DOM渲染是浏览器展现给用户的DOM文档的生成的过程. DOM渲染的演化过程: ①纯后端渲染 ②纯前端渲染 ③服务端的js渲染结合前端渲染 纯后端渲染:DOM树的生成完全是在后端服 ...