JavaSE-设计模式/11.设计模式-组合模式
何须浅碧深红色,自是花中第一流。
——李清照《鹧鸪天》
## 设计模式-组合模式1. 案例引出组合模式
编写程序展示一个学校院系结构(使用数据库中的表间关系很容易实现,注意这里是使用Java程序实现):需求是这样,
要在一个页面中展示出学校的院系组成,一个学校有多个学院,一个学院有多个专业,
如下图:传统方式解决上述问题(类图如下):
传统方案存在的问题:
- 将学院看做是学校的子类, 专业是学院的子类,这样实际上是站在组织大小来进行分层次的。
- 实际上我们的要求是 :在一个页面中展示出学校的院系组成,一个学校有多个学院,一个学院有多个专业, 因此这种方案, 不能很好实现的管理的操作,比如对学院、专业的 添加,删除,遍历等。
- 解决方案:把学校、院、系都看做是组织结构,他们之间没有继承的关系,而是一个树形结构,可以更好的实现管理操作。这就要使用到设计模式中的组合模式。
2. 组合模式
2.1 组合模式基本介绍
组合模式(Composite Pattern),又叫部分整体模式
,它创建了对象组的树形结构,将对象组合成树状结构以表示“ 整体- 部分”的层次关系
。- 组合模式依据树形结构来组合对象,用来表示部分以及整体层次。
- 这种类型的设计模式属于结构型模式。
组合模式使得 用户对单个对象和组合对象的访问具有一致性,即:组合能让客户以一致的方式处理个别对象以及组合对象。
2.2 组合模式类图
- Component :这是组合中对象声明接口,在适当情况下,实现所有类共有的接口默认行为,用于访问和管理Component 子部件, Component 可以是抽象类或者接口。
- Leaf : 在组合中表示叶子节点,叶子节点没有子节点。
- Composite :非叶子节点, 用于存储子部件, 在 Component 接口中实现 子部件的相关操作,比如增加(add),删除。
2.3 组合模式解决学校院系展示
类图结构
代码实现
OrganizationComponent
1 | public abstract class OrganizationComponent { |
University--Composite
1 |
|
College
1 | public class College extends OrganizationComponent { |
Department
1 |
|
Client
1 | public class Client { |
3 .组合模式在 JDK Map集合源码体现
Java 的集合类
HashMap
就使用了组合模式
HashMap
中的静态内部类Node相当于组合模式的中的Leaf 即叶子节点,叶子节点没有子节点。Map接口相当于组合模式中的Component对象声明接口,用于访问和管理Component 子部件。
而
HashMap
相当于组合模式中的Composite非叶子节点, 用于存储子部件,具体通过两个 方法体现出:
putAll
public void putAll(Map<? extends K, ? extends V> m)
1 | /** |
put
public V put(K key, V value) ;
1 | /** |
Node
1 |
|
put方法是将单个Node添加到
HashMap
中,而putAll
方法是将一个HashMap
放到另一个HashMap
中,通过下面的关系映射:
- Node —-> 专业
- put —-> 院系添加专业
putAll
—-> 学校添加院系因为put和
putAll
都是HashMap
中的方法,所以HashMap
相当于组合模式中的Composite
非叶子节点。这样下来就可以理解了,面试的时候又可以吹一波了哈哈哈