(十二)组合模式建模与实现

最后更新于: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) ##三、应用场景 将多个对象组合在一起进行操作,常用于表示树形结构中,例如二叉树等。 ##四、总结 组合能让客户以一致的方式处理个别对象以及对象组合。
';