组合模式composite 树形结构就用组合模式 组合模式核心 抽象构件(component)角色:定义了叶子和容器构建的共同特点 叶子构件(Leaf)角色:无子节点 容器构件(Composite)角色:有容器特征,可以包含子节点
运用的场景 把部分和整体的关系用树形结构来表示;从而使客户端可以使用统一的方式处理部分对象和整体结构
组合和组合模式不是一回事 组合:A类中定义一个B类对象可以使用B类就组合了
组合模式工作流程分析 组合模式为处理树形结构提供了完美的解决方案,描述了如何将容器和叶子进行递归组合,使得用户在使用时可以一致性的对待容器和叶子 当容器对象的指定方法被调用时,将遍历整个树形结构,寻找也包含这个方法的成员,并调用执行。其中,使用递归调用的机制对整个结构进行处理
package studyGFO; //抽象构件(component)角色:定义了叶子和容器构建的共同特点 public interface Component { void operation(); } // 叶子构件(Leaf)角色:无子节点 interface Leaf extends Component { } // 容器构件(Composite)角色:有容器特征,可以包含子节点 interface Composite extends Component { void add(Component c); void remove(Component c); Component getChild(int index); }使用组合模式,模拟杀毒软件架构设计
package studyGFO; import java.util.ArrayList; import java.util.List; //抽象构件 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{ private String name; //定义容器,用来存放本容器构建下的子节点 private List<AbstractFile> list = new ArrayList<>(); public Folder(String name) { super(); this.name = name; } public void add(AbstractFile file) { list.add(file); } public void remove(AbstractFile file) { list.remove(file); } public AbstractFile getChild(int index) { return list.get(index); } @Override public void killVirus() { System.out.println("---文件夹"+name+"进行查杀"); for(AbstractFile file:list){ //递归 file.killVirus(); } } } package studyGFO; public class Client { public static void main(String[] args) { AbstractFile f2,f3,f4,f5,f6; Folder f1 = new Folder("我的收藏"); f2 = new ImageFile("我的照片"); f3 = new VideoFile("我的视频"); f1.add(f2); f1.add(f3); Folder f01 = new Folder("我的收藏"); f4 = new VideoFile("低俗小说"); f5 = new VideoFile("杀死比尔"); f01.add(f4); f01.add(f5); //加上f01一起扫描 树形结构 f1.add(f01); //因为继承了同一个接口 //统一的方式处理整体对象 f1.killVirus(); //统一的方式处理部分对象 //f2.killVirus(); } }开发场景中的应用场景 操作系统的资源管理器 gui中的容器层次图 xml文件解析 OA系统中的,组织结构的处理 Junit单元测试框架 底层设计就是典型的组合模式,Testcase(叶子),TestUnite(容器),Test(接口)