组合模式(Composite)
:将对象组合成树形结构以表示‘部分-整体’的层次结构。组合模式使得用户对单个对象和组合对象的使用具有一致性。
当在需求中有体现部分与整体层次结构,并且用户可以忽略组合对象与单个对象的不同,统一地使用组合结构中的所有对象时,就可以考虑使用组合模式。
优点
组合模式可以让客户一致地使用组合结构和单个对象。
在组合模式中定义了基本对象和组合对象类层次结构。基本对象可以被组合成更复杂的组合对象,并且这些组合对象还可以被组合,这样不断地递归下去,这样在客户代码中,任何用到基本对象的地方都可以使用组合对象。
透明方式与安全方式
透明方式:实现Component接口的所有子类都具了Add和Remove,这里就表明叶子节点和枝节点对于外界没有区别,它们具备一致的行为接口。但是Leaf是叶子结点,实现它是没有意义的。
安全方式:在Component接口中不声明Add和Remove方法,需要在Composite中声明所有用来管理子类对象的方法,不过由于不透明,在树叶类和树枝类将不具备相同的接口,客户端的调用需要做相应的判断,有一定的不便。
#include <iostream>
#include <Composite.h>
#include <Leaf.h>
using namespace std;
int main()
{
Composite *root = new Composite("root");
root->Add(new Leaf("Leaf A"));
root->Add(new Leaf("Leaf B"));
Composite *comp = new Composite("Composite X");
comp->Add(new Leaf("Leaf XA"));
comp->Add(new Leaf("Leaf XB"));
root->Add(comp);
Composite *comp2 = new Composite("Composite XY");
comp2->Add(new Leaf("Leaf XYA"));
comp2->Add(new Leaf("Leaf XYB"));
comp->Add(comp2);
root->Add(new Leaf("Leaf C"));
Leaf *leaf = new Leaf("Leaf D");
root->Add(leaf);
root->Remove(leaf);
root->Display(1);
getchar();
}
输出
-root
---Leaf A
---Leaf B
---Composite X
-----Leaf XA
-----Leaf XB
-----Composite XY
-------Leaf XYA
-------Leaf XYB
---Leaf C