码迷,mamicode.com
首页 > 编程语言 > 详细

Java设计模式菜鸟系列(十二)组合模式建模与实现

时间:2014-10-06 18:41:40      阅读:222      评论:0      收藏:0      [点我收藏+]

标签:设计模式   java设计模式   模式   uml   架构   

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


组合模式(Composite):组合模式有时又叫部分-整体模式,将对象组合成树形结构来表示“部分-整体”层次结构。组合模式在处理树形结构的问题时比较方便。

一、uml建模:

bubuko.com,布布扣


二、代码实现

/**
 * 示例:组合模式有时也称“整合-部分”模式
 * 
 * 组合模式在处理树形结构的问题时比较方便
 * 
 * 节点
 */
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());
		}
	}
}
说明,这里构造了这样一棵树:

bubuko.com,布布扣


三、应用场景

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


四、总结

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



Java设计模式菜鸟系列(十二)组合模式建模与实现

标签:设计模式   java设计模式   模式   uml   架构   

原文地址:http://blog.csdn.net/lhy_ycu/article/details/39828653

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!