组合模式
内容
把部分和整体的关系用树形结构来表示,从而使客户端可以使用统一的方式处理部分对象和整体对象
核心
- 抽象构件(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接口(抽象)