1.概念
组合模式(Composite):将对象组合成树形结构以表示‘部分-整体’的层次结构。组合模式使得用户对单个对象和组合对象的使用具有一致性。
2.理解
我们可以将树形结构的树理解成一个大的容器,容器里包含很多成员对象,这些成员对象即可是容器对象也可以是叶子对象。但是由于容器对象和叶子对象在功能上面的区别,使得我们在使用的过程中必须要区分容器对象和叶子对象,但是这样就会给客户带来不必要的麻烦,作为客户而已,它始终希望能够一致的对待容器对象和叶子对象。这就是组合模式的设计动机:组合模式定义了如何将容器对象和叶子对象进行递归组合,使得客户在使用的过程中无须进行区分,可以对他们进行一致的处理。
计算机的文件系统是用递归结构来进行组织的,对于这样的数据结构是非常适用使用组合模式的。在使用组合模式中需要注意一点也是组合模式最关键的地方:叶子对象和组合对象实现相同的接口。这就是组合模式能够将叶子节点和对象节点进行一致处理的原因。
说白了,就是用递归解决树的问题,同时处理好叶子节点。
3.实现
组合模式主要包含如下几个角色:
3.1 Component :组合中的对象声明接口,在适当的情况下,实现所有类共有接口的默认行为。声明一个接口用于访问和管理Component子部件。
3.2 Leaf:叶子对象。叶子结点没有子结点。
3.3 Composite:容器对象,定义有枝节点行为,用来存储子部件,在Component接口中实现与子部件有关操作,如增加(add)和删除(remove)等。
从模式结构中我们看出了叶子节点和容器对象都实现Component接口,这也是能够将叶子对象和容器对象一致对待的关键所在。
另外,组合模式可以根据节点的处理方式是否都一致进行分类。当叶子节点的接口和其他非叶子节点接口一致时,即具备完全一致的行为接口,叫做透明方式,用户在使用的时候不用判断是否是叶子节点,因为在叶子节点实现的方法中已经写好了。当叶子节点不去声明Add和Remove方法时,叶子节点和树枝节点不具备相同的接口,客户端使用时候需要自己判断,也就是安全模式。一般用户喜欢使用透明方式。
4.1 优点
4.1.1 可以清楚地定义分层次的复杂对象,表示对象的全部或部分层次,使得增加新构件也更容易。
4.1.2 客户端调用简单,客户端可以一致的使用组合结构或其中单个对象。
4.1.3 定义了包含叶子对象和容器对象的类层次结构,叶子对象可以被组合成更复杂的容器对象,而这个容器对象又可以被组合,这样不断递归下去,可以形成复杂的树形结构。
4.1.4 更容易在组合体内加入对象构件,客户端不必因为加入了新的对象构件而更改原有代码。
4.2 缺点
使设计变得更加抽象,对象的业务规则如果很复杂,则实现组合模式具有很大挑战性,而且不是所有的方法都与叶子对象子类都有关联
4.3 适用场景
4.3.1 需要表示一个对象整体或部分层次,在具有整体和部分的层次结构中,希望通过一种方式忽略整体与部分的差异,可以一致地对待它们。
4.3.2 让客户能够忽略不同对象层次的变化,客户端可以针对抽象构件编程,无须关心对象层次结构的细节。