组合模式(Composite):组合模式有时又叫部分-整体模式,将对象组合成树形结构来表示“部分-整体”层次结构。组合模式在处理树形结构的问题时比较方便。
##一、uml建模:
![](https://box.kancloud.cn/2016-02-19_56c7196e0a5db.jpg)
##二、代码实现
~~~
/**
* 示例:组合模式有时也称“整合-部分”模式
*
* 组合模式在处理树形结构的问题时比较方便
*
* 节点
*/
class TreeNode {
/**节点名称 */
private String name;
private TreeNode parent;
private ArrayList<TreeNode> children = new ArrayList<TreeNode>();
public TreeNode(String name) {
this.name = name;
}
/**
* 对相关属性进行封装
*/
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public TreeNode getParent() {
return parent;
}
public void setParent(TreeNode parent) {
this.parent = parent;
}
/**
* 对孩子节点的增删查操作
*/
public void add(TreeNode node) {
children.add(node);
}
public void delete(TreeNode node) {
children.add(node);
}
public Iterator<TreeNode> getChildren() {
return children.iterator();
}
}
/**
* 客户端测试类
*
* @author Leo
*/
public class Test {
public static void main(String[] args) {
TreeNode rootNode = new TreeNode("A");
TreeNode bNode = new TreeNode("B");
TreeNode cNode = new TreeNode("C");
TreeNode dNode = new TreeNode("D");
rootNode.add(bNode);
rootNode.add(cNode);
cNode.add(dNode);
Iterator<TreeNode> iterator = rootNode.getChildren();
while (iterator.hasNext()) {
System.out.println(iterator.next().getName());
}
}
}
~~~
**说明**,这里构造了这样一棵树:
![](https://box.kancloud.cn/2016-02-19_56c7196e18f25.jpg)
##三、应用场景
将多个对象组合在一起进行操作,常用于表示树形结构中,例如二叉树等。
##四、总结
组合能让客户以一致的方式处理个别对象以及对象组合。
- 前言
- (一)策略模式建模与实现
- (二)观察者模式建模与实现
- (三)装饰者模式建模与实现
- (四)工厂方法模式建模与实现
- (五)抽象工厂模式建模与实现
- (六)单例模式建模与实现
- (七)命令模式建模与实现
- (八)适配器模式建模与实现
- (九)外观模式建模与实现
- (十)模板方法模式建模与实现
- (十一)迭代器模式建模与实现
- (十二)组合模式建模与实现
- (十三)状态模式建模与实现
- (十四)代理模式建模与实现
- (十五)建造者模式建模与实现
- (十六)原型模式建模与实现
- (十七)桥接模式建模与实现
- (十八)责任链模式建模与实现
- (十九)备忘录模式建模与实现
- (二十)解释器模式建模与实现
- (二十一)享元模式建模与实现
- (二十二)中介者模式建模与实现
- (二十三)访问者模式建模与实现
- Java设计模式博客全目录