zoukankan      html  css  js  c++  java
  • 设计模式-组合模式

    连接:

    http://www.2cto.com/kf/201206/137680.html

    http://edison-cool911.iteye.com/blog/1727712

    组合模式的关键是定义了一个抽象构件类,它既可以代表叶子,又可以代表容器,而客户端针对该抽象构件类进行编程,无须知道它到底表示的是叶子还是容器,可以对其进行统一处理。
    同时容器对象与抽象构件类之间还建立一个聚合关联关系,在容器对象中既可以包含叶子,也可以包含容器,以此实现递归组合,形成一个树形结构。
     
     
    模式优缺点
    组合模式的优点
    •可以清楚地定义分层次的复杂对象,表示对象的全部或部分层次,使得增加新构件也更容易。
    •客户端调用简单,客户端可以一致的使用组合结构或其中单个对象。
    •定义了包含叶子对象和容器对象的类层次结构,叶子对象可以被组合成更复杂的容器对象,而这个容器对象又可以被组合,这样不断递归下去,可以形成复杂的树形结构。
    •更容易在组合体内加入对象构件,客户端不必因为加入了新的对象构件而更改原有代码。
     
    模式优缺点
    组合模式的缺点
    •使设计变得更加抽象,对象的业务规则如果很复杂,则实现组合模式具有很大挑战性,而且不是所有的方法都与叶子对象子类都有关联。
    •增加新构件时可能会产生一些问题,很难对容器中的构件类型进行限制。
     
     
    实例:xml 文档解析,folder文件目录,layout的组件,
     
     
     
    /**
     * 组合模式--文件夹大小
     * 关键点 抽象构件类,聚合关系
     * @author wangjianwei
     *
     */
    public class CompositeTest {
    
    	public static abstract class BaseFile {
    
    		public int getSize() {
    			int size = 0;
    			for (int i = 0; i < mFileList.size(); i++) {
    				size += mFileList.get(i).getSize();
    			}
    			return size;
    		}
    
    		ArrayList<BaseFile> mFileList = new ArrayList<BaseFile>();
    
    		public void add(BaseFile baseFile) {
    			mFileList.add(baseFile);
    		}
    
    	}
    	
    	public static class CustomFolder extends BaseFile{
    		@Override
    		public int getSize() {
    			return 0+super.getSize();
    		}
    	}
    
    	public static class CustomTxtFile extends BaseFile {
    		@Override
    		public int getSize() {
    			return 1000;//1k
    		}
    		
    		@Override
    		public void add(BaseFile baseFile) {
    //			super.add(baseFile);
    		}
    	}	
    	
    	
    	public static void main(String[] args) {
    		CustomFolder folder = new CustomFolder();
    		folder.add(new CustomTxtFile());
    		folder.add(new CustomTxtFile());
    		CustomFolder folder1 = new CustomFolder();
    		folder1.add(new CustomTxtFile());
    		folder1.add(new CustomTxtFile());
    		folder.add(folder1);
    		System.out.println(folder.getSize());
    	}
    

      

     
     
     
  • 相关阅读:
    批处理命令系列
    CMD批处理之PC查看连过的WIFI密码
    数据结构与算法之各种方法遍历二叉树
    二叉树同构判定算法
    卡拉兹(Callatz)猜想
    Java之字符串比较大小
    Java报错之StackOverflowError
    火绒勒索病毒诱捕技术浅析
    数据结构与算法之二叉链树
    数据结构与算法之广义表的基本运算
  • 原文地址:https://www.cnblogs.com/wjw334/p/3607607.html
Copyright © 2011-2022 走看看