组合模式就是 处理树结构的,
树结构 分为容器节点(有孩子节点的)和叶子节点(末端节点)
组合模式可以统一处理 容器节点 和叶子节点; 他拥有天然的递归系统
上代码:
package composite;
import java.util.ArrayList;
import java.util.List;
public interface AbstractFile {
void killVirus();
}
class ImgFile implements AbstractFile{
private String name;
@Override
public void killVirus() {
// TODO Auto-generated method stub
System.out.println( this.name +"图片已杀毒");
}
public ImgFile(String name) {
super();
this.name = name;
}
}
class TextFile implements AbstractFile{
private String name;
@Override
public void killVirus() {
// TODO Auto-generated method stub
System.out.println( this.name +"文章已杀毒");
}
public TextFile(String name) {
super();
this.name = name;
}
}
class Folder implements AbstractFile{
private String name;
private List<AbstractFile> list= new ArrayList<AbstractFile>();
public Folder(String name) {
super();
this.name = name;
}
@Override
public void killVirus() {
// TODO Auto-generated method stub
System.out.println( this.name +"文件夹已杀毒");
for (AbstractFile abstractFile : list) {
abstractFile.killVirus();
}
}
public void add(AbstractFile a) {
this.list.add(a);
}
public void remove(AbstractFile a) {
this.list.remove(a);
}
public void getFile(int i) {
this.list.get(i);
}
}
// 调用
package composite;
public class Client {
public static void main(String[] args) {
Folder f1 = new Folder("我的收藏");
Folder f2 = new Folder("我的照片");
Folder f3 = new Folder("我的文章");
AbstractFile img = new ImgFile("leon");
AbstractFile text1 = new TextFile("生化危机1-恶化");
AbstractFile text2 = new TextFile("生化危机终章-进化");
f2.add(img);
f3.add(text1);
f3.add(text2);
f1.add(f2);
f1.add(f3);
f1.killVirus();
}
}