背景
首先我们来理解下"部分-整体",在现实生活中的这种关系"部分-整体"也很常见。比如:学院与学校,分公司与总公司,书与书柜等等。
在软件开发中我们常常有对简单对象与复合对象的处理,可以使用组合模式一致地处理单个对象与复合对象,客户端无需关系要调用的是单个对象还是复合对象。这种通用性很好地减少了客户端的代码。
上面的介绍是不是比较抽象?别急,请继续往下看。
什么是组合模式
“
Compose objects into tree structures to represent part-whole hierarchies.Composite lets clients treat individual objects and compositions of objects uniformly.(将对象组合成树形结构以表示"部分-整体"的层次结构,使得用户对单个对象和组合对象的使用具有一致性。)
”
组合模式主要有3个要素构成:
“抽象构件(Component)角色:它的主要作用是为树叶构件和树枝构件声明公共接口,并实现它们的默认行为。树叶构件(Leaf)角色:是组合中的叶节点对象,它没有子节点,用于实现抽象构件角色中 声明的公共接口。树枝构件(Composite)角色:是组合中的分支节点对象,它有子节点。它实现了抽象构件角色中声明的接口,它的主要作用是存储和管理子部件,通常包含 Add()、Remove()、GetChild() 等方法。”
组合模式结构简图如下。
组合模式
代码实现
Component
Leaf
Composite
测试代码:
这个测试代码是干什么事情的呢?我们用来遍历Leaf中的内容的。
遍历
测试结果如下:
树叶Lvshen1:被访问!树叶Lvshen2:被访问!树叶Lvshen3:被访问!
关于组合模式的思考
关于上述代码Leaf就是单个对象,Composite就是复合对象。对客户端来说,调用的是Component,整体和局部没有任何区别。Composite既能装载自己也能装载Leaf,只需要一套代码就能满足。
使用了组合模式后,我们可以看到,如果想增加一个树枝(Composite)节点、树叶(Leaf)节点是不是都很容易,只要找到它的父节点就成,非常容易扩展,符合开闭原则,对以后的维护非常有利。
那么我们什么情况使用它呢?
在开发中我们如果有需要展示"局部-整体"的场景,例如树形菜单、文件与文件夹管理等等都可以使用组合模式。
还有如果你需要开发管理系统,可能涉及到人员职级关系图的开发。比如总经理-部门经理-员工这样的树形结构。
还有电商分销系统中,需要展示上线与下线关系。也可以使用组合模式。