设计模式之组合模式composite

组合模式

内容
把部分和整体的关系用树形结构来表示,从而使客户端可以使用统一的方式处理部分对象和整体对象
 
核心
  • 抽象构件(Component)角色:定义了叶子和容器构件的共同点
  • 叶子(Leaf)构件角色:无子节点
  • 容器(Composite)构件角色:有容器特征,可以包含子节点

结构图:


 
组合模式工作流程分析
  • 组合模式为处理树形结构提供了完美的解决方案,描述了如何将容器和叶子进行递归组合,使得用户在使用时可以一致性的对待容器和叶子
  • 当容器对象的指定方法被调用时,将遍历整个树形结构,寻找也包含这个方法的成员,并调用执行,其中,使用了递归调用的机制对整个结构进行处理

实例代码

1.模板

/**
 * 抽象组件
 */

public interface Component {
    void operation();
}

//叶子组件
interface Leaf extends Component{

}

//容器组件
interface Composite extends Component{
    void add(Component c);
    void remove(Component c);
    Component getChild(int index);
}

2.实例

public interface AbstractFile {
    void killVirus();
}

//具体文件 叶子节点
class ImageFile implements AbstractFile{
    private String name;

    public ImageFile(String name){
        super();
        this.name = name;
    }

    @Override
    public void killVirus() {
       System.out.println("杀图片文件:"+name+"--的病毒");
    }
}

class TextFile implements AbstractFile{
    private String name;

    public TextFile(String name){
        super();
        this.name = name;
    }

    @Override
    public void killVirus() {
        System.out.println("杀文本文件:"+name+"的病毒");
    }
}

class VideoFile implements AbstractFile{
    private String name;

    public VideoFile(String name){
        super();
        this.name = name;
    }

    @Override
    public void killVirus() {
        System.out.println("杀视频文件"+name+"的病毒");
    }
}

//容器

class Folder implements AbstractFile{

    String name;

    List<AbstractFile> list = new ArrayList<>();//保存容器的子节点

    public Folder(String name){
        super();
        this.name = name;
    }

    void add(AbstractFile c){
        list.add(c);
    }

    void remove(AbstractFile c){
        list.remove(c);
    }

    AbstractFile getChild(int index){
        return list.get(index);
    }

    @Override
    public void killVirus() {
        System.out.println("对文件夹:"+name+"进行查杀");
        //进行递归处理
        for(AbstractFile file : list){
            file.killVirus();
        }
    }

}


ublic class Client {

    public static void main(String[] args){

        AbstractFile file1,file2,file3;
        Folder folder = new Folder("文件夹");
        file1 = new ImageFile("girl.jpg");
        file2 = new TextFile("test.txt");
        file3 = new VideoFile("video.bmp");

        folder.add(file1);
        folder.add(file2);
        folder.add(file3);
        folder.killVirus();

    }
}

  

场景
  • 操作系统的资源管理器
  • XML文件解析
  • OA系统中,组织结构的处理
  • Junit单元测试框架:底层设计就是典型的组合模式,TestCase叶子节点,TestUnite容器,Test接口(抽象) 

猜你喜欢

转载自jenny-run.iteye.com/blog/2297109