设计模式之组合模式

组合模式(Composite)

定义

将对象组合成树形结构以表示"部分-整体"的层次结构。

使用场景

  • 当你的程序结构有类似树一样的层级关系时,例如文件系统,视图树,公司组织架构等等
  • 当你要以统一的方式操作单个对象和由这些对象组成的组合对象的时候。

主要角色

  1. Component(组件)
  2. Leaf(叶子节点)
  3. Composite(组合节点)

类图

示例代码

安全模式

java 复制代码
public interface FileSystemComponent {
    void display();
}
java 复制代码
public class File implements FileSystemComponent {
    private final String name;

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

    @Override
    public void display() {
        System.out.println("File: " + name);
    }
}
java 复制代码
public class Folder implements FileSystemComponent {
    private final String name;
    private final List<FileSystemComponent> components;

    public Folder(String name) {
        this.name = name;
        this.components = new ArrayList<>();
    }

    public void addComponent(FileSystemComponent component) {
        components.add(component);
    }

    @Override
    public void display() {
        System.out.println("Folder: " + name);
        for (FileSystemComponent component : components) {
            component.display();
        }
    }
}
java 复制代码
public class Client {
    public static void main(String[] args) {
        // 创建文件和文件夹
        File file1 = new File("file1.txt");
        File file2 = new File("file2.txt");
        Folder folder1 = new Folder("Folder 1");
        Folder folder2 = new Folder("Folder 2");

        // 组合节点包含叶子节点
        folder1.addComponent(file1);
        folder1.addComponent(file2);

        // 组合节点包含另一个组合节点
        folder2.addComponent(folder1);

        // 显示整个文件系统结构
        folder2.display();
    }
}
java 复制代码
Folder: Folder 2
Folder: Folder 1
File: file1.txt
File: file2.txt

透明模式

java 复制代码
public interface FileSystemComponent {
    void display();

    void addComponent(FileSystemComponent component);
}
java 复制代码
public class File implements FileSystemComponent {
    private final String name;

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

    @Override
    public void display() {
        System.out.println("File: " + name);
    }

    @Override
    public void addComponent(FileSystemComponent component) {
        throw new UnsupportedOperationException(this.name + "是文件,不支持添加");
    }
}
java 复制代码
public class Folder implements FileSystemComponent {
    private final String name;
    private final List<FileSystemComponent> components;

    public Folder(String name) {
        this.name = name;
        this.components = new ArrayList<>();
    }

    public void addComponent(FileSystemComponent component) {
        components.add(component);
    }

    @Override
    public void display() {
        System.out.println("Folder: " + name);
        for (FileSystemComponent component : components) {
            component.display();
        }
    }
}
java 复制代码
public class Client {
    public static void main(String[] args) {
        // 创建文件和文件夹
        FileSystemComponent file1 = new File("file1.txt");
        FileSystemComponent file2 = new File("file2.txt");
        FileSystemComponent folder1 = new Folder("Folder 1");
        FileSystemComponent folder2 = new Folder("Folder 2");

        // 组合节点包含叶子节点
        folder1.addComponent(file1);
        folder1.addComponent(file2);

        // 组合节点包含另一个组合节点
        folder2.addComponent(folder1);

        // 显示整个文件系统结构
        folder2.display();
    }
}
相关推荐
alibli3 小时前
一文学会设计模式之创建型模式及最佳实现
c++·设计模式
1024肥宅4 小时前
前端常用模式:提升代码质量的四大核心模式
前端·javascript·设计模式
郝学胜-神的一滴9 小时前
设计模式依赖于多态特性
java·开发语言·c++·python·程序人生·设计模式·软件工程
帅次9 小时前
系统分析师:软件需求工程的软件需求概述、需求获取、需求分析
设计模式·重构·软件工程·团队开发·软件构建·需求分析·规格说明书
EXtreme359 小时前
【数据结构】算法艺术:如何用两个栈(LIFO)优雅地模拟队列(FIFO)?
c语言·数据结构·算法·设计模式·栈与队列·摊还分析·算法艺术
1024肥宅1 天前
JavaScript常用设计模式完整指南
前端·javascript·设计模式
特立独行的猫a1 天前
C++观察者模式设计及实现:玩转设计模式的发布-订阅机制
c++·观察者模式·设计模式
better_liang1 天前
每日Java面试场景题知识点之-单例模式
java·单例模式·设计模式·面试·企业级开发
sg_knight1 天前
什么是设计模式?为什么 Python 也需要设计模式
开发语言·python·设计模式
koping_wu1 天前
【设计模式】设计模式原则、单例模式、工厂模式、模板模式、策略模式
单例模式·设计模式·策略模式