cvmachine.com - 申博开户网

搜索: 您的位置主页 > 手机频道 > 阅读资讯:Java设计模式学习08——组合模式

Java设计模式学习08——组合模式

2019-03-29 16:18:01 来源:www.cvmachine.com 【

一、组合模式适用场景


把部分和整体的关系用树形结构来表示,从而使客户端可以使用统一的方式对部分对象和整体对象进行管理。

二、组合模式结构


  • 抽象构件(Conponent)角色:所有类的共有接口,定义了叶子和容器的共同点。
  • 叶子(Leaf)构件角色:在组合中表示叶子结点对象,叶子节点无子节点。
  • 容器(Composite)构件角色:有容器特征,可以 用来存储子节点,在Component接口中实现与子节点有关操作,如增加(add)和删除 (remove)等。

Java设计模式学习08——组合模式

组合模式工作流程分析


  • 组合模式为处理树形结构提供了完美的解决方案,描述了如何将容器和叶子进行递归组合,使得用户在使用时可以一致性的对待容器和叶子。
  • 当容器对象的指定方法被调用时,将遍历整个树形结构,寻找包含这个方法的成员,并调用执行。其中,使用递归调用机制对整个结构进行处理。

下面通过简单的杀毒例子,使用组合模式:
示例代码:
1.抽象构件

public interface AbstractFile {
  void killVirus();//杀毒
}

2. 叶子构件

class ImageFile implements AbstractFile{
  private String name;

  public ImageFile(String name){
    this.name=name;
  }

  public void killVirus() {
    System.out.println("---对图像文件"+name+"杀毒");

  }

}
class TextFile implements AbstractFile{
  private String name;

  public TextFile(String name){
    this.name=name;
  }

  public void killVirus() {
    System.out.println("---对文本文件"+name+"杀毒");

  }

}

3. 容器构件

class Folder implements AbstractFile{
  private String name;
  private ArrayList<AbstractFile> list=new ArrayList<AbstractFile>();
  public Folder(String name){
    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);
  }

  public void killVirus() {
    System.out.println("---对文件夹"+name+"杀毒");
    for(AbstractFile file:list){
      file.killVirus();
    }

  }

}

4.客户端

public class Client {

  public static void main(String[] args) {
    Folder f1;
    AbstractFile f2,f3;

    f1=new Folder("我的收藏");
    f2=new ImageFile("my.jpg");
    f3=new TextFile("my.txt");
    f1.add(f2);
    f1.add(f3);
    f1.killVirus();

  }

}

//输出结果:
---对文件夹我的收藏杀毒
---对图像文件my.jpg杀毒
---对文本文件my.txt杀毒 
 
 

本文地址:http://www.cvmachine.com/a/luyou/99902.html
Tags: 组合 学习 Java
编辑:申博开户网
关于我们 | 联系我们 | 友情链接 | 网站地图 | Sitemap | App | 返回顶部