(十二)组合模式建模与实现
最后更新于:2022-04-01 09:31:24
组合模式(Composite):组合模式有时又叫部分-整体模式,将对象组合成树形结构来表示“部分-整体”层次结构。组合模式在处理树形结构的问题时比较方便。
##一、uml建模:
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/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://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-02-19_56c7196e18f25.jpg)
##三、应用场景
将多个对象组合在一起进行操作,常用于表示树形结构中,例如二叉树等。
##四、总结
组合能让客户以一致的方式处理个别对象以及对象组合。