组合模式:对于树形结构,当容器对象(如文件夹)的某一个方法被调用时,将遍历整个树形结构,寻找也包含这个方法的成员对象(可以是容器对象,也可以是叶子对象)并调用执行,牵一而动百,其中使用了递归调用的机制来对整个结构进行处理。由于容器对象和叶子对象在功能上的区别,在使用这些对象的代码中必须有区别地对待容器对象和叶子对象,而实际上大多数情况下我们希望一致地处理它们,因为对于这些对象的区别对待将会使得程序非常复杂。组合模式为解决此类问题而诞生,它可以让叶子对象和容器对象的使用具有一致性。
使用场景:公司上下级的部门、文件夹杀毒
代码如下:
首先定义一个抽象类:
public abstract class AbstractFile {
//添加叶子
public void add(AbstractFile abstractFile){
System.out.println("非文件夹没有此方法");
}
//删除叶子
public void remove(AbstractFile abstractFile){
System.out.println("非文件夹没有此方法");
}
//获取叶子
public AbstractFile getFile(int i){
System.out.println("非文件夹没有此方法");
return null;
}
//杀毒
public abstract void killVirus();
}
抽象类的子类:
public class ImageFile extends AbstractFile {
public void killVirus(){
System.out.println("对图像文件进行杀毒");
}
}
public class TxtFile extends AbstractFile {
public void killVirus(){
System.out.println("对文本文件进行杀毒");
}
}
public class Folder extends AbstractFile {
private ArrayList<AbstractFile> fileList = new ArrayList();
//新增文件
public void add(AbstractFile abstractFile){
fileList.add(abstractFile);
}
//删除文件
public void remove(AbstractFile abstractFile){
fileList.remove(abstractFile);
}
//获取文件
public AbstractFile getFile(int i){
return fileList.get(i);
}
public void killVirus(){
//对list 中的文件进行杀毒
for(AbstractFile abstractFile : fileList) {
abstractFile.killVirus();
}
}
}
测试类:
public class FileTest {
public static void main(String[] args){
AbstractFile file1,file2,file3,file4,file5,file6;
file1 = new ImageFile();
file2 = new TxtFile();
file3 = new TxtFile();
file4 = new ImageFile();
file5 = new TxtFile();
file6 = new Folder();
file6.add(file1);
file6.add(file2);
file6.add(file3);
file6.add(file4);
file6.add(file5);
file6.killVirus();
}
}
当对文件夹进行杀毒时,会遍历文件夹下的所有文件的杀毒操作。