什么是组合模式
组合模式就是把部分和整体的关系用树形结构来表示,从而使客户端可以使用统一的方式处理部分对象和整体对象.
组合模式必须知道的角色
抽象构建(Component)角色:定义了叶子和容器构件的共同点,为组合对象提供统一的接口.
叶子(Leaf)构件角色:表示子字节对象,
容器(Composite)构建角色:有容器特征,可以包含子节点,实现Component接口中的有关操作.
组合模式实现的关键部分
定义了一个抽象构建类,它既可以代表叶子,又可以代表容器,而客户端针对该抽象构建类进行编程,无须知道它表示的是叶子还是容器,可以对它进行统一的处理。
组合模式工作流程分析
- 组合模式为处理树形结构提供了完美的解决方案,描述了如何将容器和叶子进行递归组合,使得用户在使用时可以一致性的对待容器和叶子。
- 当容器对象的指定方法被调用时,将遍历整个树形结构,寻找也包含这个方法的成员,并调用执行。其中,使用了递归调用的机制对整个结构进行处理。
模拟杀毒软件架构设计
抽象构建:
/*
* 模拟杀毒软件架构设计
* 这个是抽象构建角色
*/
public interface AbstractFile {
void killVirus();
}
叶子组件:
//模拟杀毒软件
//叶子组件角色
//图像处理
public class ImageFile implements AbstractFile {
private String name;
public ImageFile(String name) {
// TODO Auto-generated constructor stub
this.name=name;
}
@Override
public void killVirus() {
// TODO Auto-generated method stub
System.out.println("图像文件"+name+",进行查杀");
}
}
//叶子组件,文本处理
class TextFile implements AbstractFile{
private String name;
public TextFile(String name) {
// TODO Auto-generated constructor stub
this.name=name;
}
@Override
public void killVirus() {
// TODO Auto-generated method stub
System.out.println("文本文件"+name+",进行查杀");
}
}
//叶子组件,视频处理
class VideoFile implements AbstractFile {
private String name;
public VideoFile(String name) {
this.name = name;
}
@Override
public void killVirus() {
System.out.println("视频文件: "+name+",进行查杀");
}
}
容器组件:
/*
* 模拟杀毒软件
*
*/
public class Folder implements AbstractFile{
private String name;
// 定义容器,用来存放本容器构建的子节点
private List<AbstractFile> list = new ArrayList<>();
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);
}
public Folder(String name) {
this.name = name;
}
@Override
public void killVirus() {
System.out.println("文件夹: " + name + ",进行查杀");
for (AbstractFile file : list) {
file.killVirus(); // 递归
}
}
}
测试代码:
public class Test {
public static void main(String[] args) {
AbstractFile f2,f3;
Folder f1 = new Folder("我的收藏");
f2 = new ImageFile("照片.jpg");
f3 = new TextFile("Hello.txt");
f1.add(f2);
f1.add(f3);
//f2.killVirus();
f1.killVirus();
}
}