当前位置: 首页 > article >正文

结构型模式 - 组合模式 (Composite Pattern)

结构型模式 - 组合模式 (Composite Pattern)

组合模式是一种结构型设计模式,它允许你将对象组合成树形结构以表示 “部分 - 整体” 的层次结构。组合模式使得用户对单个对象和组合对象的使用具有一致性。


经典的例子就是树形结构,里面可以是文件和文件夹的组合,文件夹还可以再往下组合文件夹和文件.

// 抽象组件类,定义文件和文件夹的公共操作
abstract class FileSystemComponent {
    protected String name;

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

    // 获取组件名称
    public String getName() {
        return name;
    }

    // 显示组件信息,具体实现由子类完成
    public abstract void display();

    // 以下方法在叶子节点(文件)中不做实际操作,在组合节点(文件夹)中实现
    public void add(FileSystemComponent component) {
        throw new UnsupportedOperationException("不支持该操作");  // 默认抛出异常, 只有文件夹类型的去重写就行
    }

    public void remove(FileSystemComponent component) {
        throw new UnsupportedOperationException("不支持该操作");
    }

    public FileSystemComponent getChild(int index) {
        throw new UnsupportedOperationException("不支持该操作");
    }
}
// 叶子节点类,代表文件
class File extends FileSystemComponent {
    public File(String name) {
        super(name);
    }

    // 显示文件信息
    @Override
    public void display() {
        System.out.println("文件: " + getName());
    }
}
import java.util.ArrayList;
import java.util.List;

// 组合节点类,代表文件夹
class Folder extends FileSystemComponent {
    private List<FileSystemComponent> children = new ArrayList<>();

    public Folder(String name) {
        super(name);
    }

    // 显示文件夹及其子组件信息
    @Override
    public void display() {
        System.out.println("文件夹: " + getName());
        for (FileSystemComponent component : children) {
            System.out.print("  ");
            component.display();
        }
    }

    // 添加子组件
    @Override
    public void add(FileSystemComponent component) {
        children.add(component);
    }

    // 移除子组件
    @Override
    public void remove(FileSystemComponent component) {
        children.remove(component);
    }

    // 获取指定索引的子组件
    @Override
    public FileSystemComponent getChild(int index) {
        return children.get(index);
    }
}

父类默认给 add, remove, getChild 抛出异常, 文件夹类重写父类 add, remove, getChild, 来达到文件夹类有这些方法, 而文件类没有.

这种编码形式可以借鉴, 可以在一定程度上规避一些问题.


http://www.kler.cn/a/563909.html

相关文章:

  • Prompt——绘制泳道图
  • vue3-07模拟vue3的响应式原理Proxy (代理对象)与Reflect (反射对象)
  • 《论企业集成平台的理解与应用》审题技巧 - 系统架构设计师
  • 判断一个链表是否为回文结构(C++)
  • 【01】Cocos游戏开发引擎从0开发一款游戏-cocos环境搭建以及配置-Cocos Creator软件系统下载安装-node环境-优雅草卓伊凡
  • 数仓搭建实操(传统数仓orale):DM数据集市层
  • 《论软件维护方法及其应用》审题技巧 - 系统架构设计师
  • 初识Skywalking
  • MuMu模拟器Pro for Mac 安卓手机平板模拟器
  • 在 WPF 项目中集成 Hangfire
  • 防爆手机科普:与普通手机的区别?在危险作业场景扮演什么角色?
  • DeepSeek开源周第二弹:DeepEP如何用RDMA+FP8让MoE模型飞起来?
  • Vue 项目中配置代理的必要性与实现指南
  • ZT15 小红的区间查询
  • FastAPI系列:Ubuntu部署FastAPI项目实战
  • 【MySQL篇】表的操作
  • Vue.js组件开发:从基础到进阶
  • Burp Suite Professional 2024版本安装激活指南
  • 算法系列之递归反转单链表
  • 四款 AI 协作办公工具,AI工具库革新办公效率