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


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


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

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

    一、uml建模:



    二、代码实现

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


    三、应用场景

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


    四、总结

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



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

  • 相关阅读:
    2021年-组装ITX台式机电脑
    jetbrain idea误删文件的两种恢复的方法
    Jmeter Macbook上利用命令行ssh tunnel 开启mysql链接
    pipeline buildResult 和 stageResult的区别
    Jenkins Pipeline ample 样板
    docker删除镜像
    C++内存分区
    auto | auto& | auto&&
    一种简易的音频信号延迟测量方案
    自制一个简易的任意音频信号发生器
  • 原文地址:https://www.cnblogs.com/zfyouxi/p/4638708.html
Copyright © 2020-2023  润新知