组合模式
内容
把部分和整体的关系用树形结构来表示,从而使客户端可以使用统一的方式处理部分对象和整体对象
核心
- 抽象构件(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接口(抽象)
相关推荐
将对象组合成树形结构以表示“部分-整体”的层次结构。它使得客户对单个对象和复合对象的使用具有一致性。
设计模式C++学习之组合模式(Composite)
C++设计模式课件20_Composite_组合模式.pdf
组合模式(Composite Pattern),又叫部分整体模式,是用于把一组相似的对象当作一个单一的对象。组合模式依据树形结构来组合对象,用来表示部分以及整体层次。这种类型的设计模式属于结构型模式,它创建了对象组的...
设计模式之Composite(组合) 设计模式之Decorator(油漆工) 设计模式之Bridge 设计模式之Flyweight(享元) 行为模式: 设计模式之Template 设计模式之Memento(备忘机制) 设计模式之Observer 设计模式之Chain of ...
主要为大家详细介绍了java设计模式之组合模式Composite,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
主要为大家详细介绍了C++设计模式之组合模式Composite,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
c++设计模式-结构型模式-组合模式;qt工程;c++简单源码; 组合(Composite Pattern)模式的定义:有时又叫作整体-部分(Part-Whole)模式,它是一种将对象组合成树状的层次结构的模式,用来表示“整体-部分”的关系...
设计模式之Composite(组合) 设计模式之Decorator(油漆工) 设计模式之Bridge 设计模式之Flyweight(享元) 行为模式: 设计模式之Template 设计模式之Memento(备忘机制) 设计模式之Observer 设计模式之Chain of ...
C#面向对象设计模式纵横谈(9):Composite 组合模式(结构型模式) 体验课程
组合模式(Composite Pattern),又叫部分整体模式,是用于把一组相似的对象当作一个单一的对象。组合模式依据树形结构来组合对象,用来表示部分以及整体层次。这种类型的设计模式属于结构型模式,它创建了对象组的...
在这里与各位分享本人从网络上下载的C#面向对象设计模式纵横谈系列视频,共有25节,除了第一节需要各位贡献一点资源分以作为对本人上传资源的回馈,后面的其他资源均不需要... 这是第9节:结构型模式Composite组合模式
结构模式:设计模式之Facade(外观),设计模式之Proxy(代理),设计模式之Adapter(适配器),设计模式之Composite(组合),设计模式之Decorator(油漆工),设计模式之Bridge,设计模式之Flyweight(享元). 行为模式:设计模式之...
C#面向对象设计模式纵横谈(9):Composite 组合模式(结构型模式) (Level 300)
主要介绍了Java设计模式之组合模式(Composite模式)介绍,Composite定义:将对象以树形结构组织起来,以达成“部分-整体” 的层次结构,使得客户端对单个对象和组合对象的使用具有一致性,需要的朋友可以参考下
第15章 组合模式(Composite) 第16章 模板方法模式(Template Method) 第17章 策略模式(Strategy) 第18章 状态模式(State) 第19章 备忘录模式(Memento) 第20章 享元模式(Flyweight) 第21章 解释器模式...
C#面向对象设计模式纵横谈(9):Composite 组合模式(结构型模式) C#面向对象设计模式纵横谈(10):Decorator 装饰模式(结构型模式) C#面向对象设计模式纵横谈(11):Facade 外观模式(结构型模式) C#面向对象设计...
Head First 设计模式 (九) 迭代器与组合模式(Iterator & Composite pattern) C++实现
组合模式(Composite Pattern) 装饰器模式(Decorator Pattern) 外观模式(Facade Pattern) 享元模式(Flyweight Pattern) 代理模式(Proxy Pattern) 3 行为型模式 这些设计模式特别关注对象之间的通信。 责任...