组合模式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(接口)