设计模式之组合模式
由来
组合模式有时候又叫做部分-整体模式。在树型结构的问题中,模糊了简单元素和复杂元素的概念, 客户程序可以向处理简单元素一样来处理复杂元素,使得客户程序与复杂元素的内部结构解耦。
组合对象既可以包括单一对象,也可以包括组合对象
意图
- 将对象组合成树形结构——“部分/整体” 层次结构
- 使用户对单一对象和组合对象使用具有一致性接口
动机
- 容器对象和叶子对象进行递归组合
- 用户可以一致地对待容器对象和叶子对象
适用情形
- 表示对象的部分-整体层次结构
- 忽略总体对象与单一对象的不同
- 用户将统一使用组合结构的所有对象
结构与参与者
- Component
为组合对象声明接口
声明一个接口用于访问和管理Component的子组件 - Leaf
表示叶节点对象,没有子节点
定义图元对象的行为 - Composite
定义复合部件的行为
存储子部件 - Client
通过Component接口操纵组合部件的对象
代码示例
abstract class Component
{
public abstract operation();
public abstract add();
public abstract remove();
public abstract getChild();
}
public class Leaf : Component {
public override operation()
{
…
}
}
public class Composite:Component
{
private List< Component > mylist =new List< Component >();
public override operation(){…};
public override add() {…};
public override remove() {…};
public override getChild() {…};
}
效果
- 定义了包含基本对象和组合对象的类层次结构
- 简化客户代码, 一致使用组合对象和单个对象
- 容易增加新类型的组件
- 用户使用Component类接口与组合结构中的对象进行交互
如果接收者是叶节点,直接处理请求;
如果接收者是Composite,将请求发给它的子部件
在转发请求之前和/或之后可能执行一些辅助操作
实现
- 显式的父对象的引用
在子对象中给出父对象的引用,可以很容易地遍历所有父对象 - 最大化Component接口(透明使用)
- 声明管理子部件的操作(安全性与透明性)
- 存储组件的数据结构(链表,树, Hash)
- Java中的Swing图形包应用了此模式
类似的模型
- 类图结构上
类似装饰模式
一定程度上装饰模式是组合模式的一个特例
装饰对象只能聚集一个对象 - 区别
装饰模式动态构建功能
组合模式把对象组装为一个层次结构