Java设计模式偷跑系列(十二)组合模式建模和实现

时间:2023-03-09 04:10:30
Java设计模式偷跑系列(十二)组合模式建模和实现

转载请注明出处:http://blog.****.net/lhy_ycu/article/details/39828653

组合模式(Composite):组合模式有时又叫部分-总体模式。将对象组合成树形结构来表示“部分-总体”层次结构。

组合模式在处理树形结构的问题时比較方便。

一、uml建模:

Java设计模式偷跑系列(十二)组合模式建模和实现

二、代码实现

/**
* 演示样例:组合模式有时也称“整合-部分”模式
*
* 组合模式在处理树形结构的问题时比較方便
*
* 节点
*/
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();
} } /**
* client測试类
*
* @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());
}
}
}

说明。这里构造了这样一棵树:

Java设计模式偷跑系列(十二)组合模式建模和实现

三、应用场景

将多个对象组合在一起进行操作。经常使用于表示树形结构中。比如二叉树等。

四、总结

组合能让客户以一致的方式处理个别对象以及对象组合。

版权声明:本文博客原创文章。博客,未经同意,不得转载。