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

转载请注明出处:http://blog.csdn.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设计模式偷跑系列(十二)组合模式建模和实现


三、应用场景

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


四、总结

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



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

你可能感兴趣的:(java设计模式)