组合模式
内容
把部分和整体的关系用树形结构来表示,从而使客户端可以使用统一的方式处理部分对象和整体对象
核心
- 抽象构件(Component)角色:定义了叶子和容器构件的共同点
- 叶子(Leaf)构件角色:无子节点
- 容器(Composite)构件角色:有容器特征,可以包含子节点
结构图:
组合模式工作流程分析
- 组合模式为处理树形结构提供了完美的解决方案,描述了如何将容器和叶子进行递归组合,使得用户在使用时可以一致性的对待容器和叶子
- 当容器对象的指定方法被调用时,将遍历整个树形结构,寻找也包含这个方法的成员,并调用执行,其中,使用了递归调用的机制对整个结构进行处理
实例代码
1.模板
/**
* 抽象组件
*/
public interface Component {
void operation();
}
//叶子组件
interface Leaf extends Component{
}
//容器组件
interface Composite extends Component{
void add(Component c);
void remove(Component c);
Component getChild(int index);
}
2.实例
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{
String name;
List<AbstractFile> list = new ArrayList<>();//保存容器的子节点
public Folder(String name){
super();
this.name = name;
}
void add(AbstractFile c){
list.add(c);
}
void remove(AbstractFile c){
list.remove(c);
}
AbstractFile getChild(int index){
return list.get(index);
}
@Override
public void killVirus() {
System.out.println("对文件夹:"+name+"进行查杀");
//进行递归处理
for(AbstractFile file : list){
file.killVirus();
}
}
}
ublic class Client {
public static void main(String[] args){
AbstractFile file1,file2,file3;
Folder folder = new Folder("文件夹");
file1 = new ImageFile("girl.jpg");
file2 = new TextFile("test.txt");
file3 = new VideoFile("video.bmp");
folder.add(file1);
folder.add(file2);
folder.add(file3);
folder.killVirus();
}
}
场景
- 操作系统的资源管理器
- XML文件解析
- OA系统中,组织结构的处理
- Junit单元测试框架:底层设计就是典型的组合模式,TestCase叶子节点,TestUnite容器,Test接口(抽象)