【设计模式-组合】

server/2024/9/23 5:17:00/

**Composite Pattern(组合模式)**是一种结构型设计模式,旨在将对象组合成树形结构,以表示“部分-整体”的层次结构。这种模式允许客户端以统一的方式处理单个对象和对象集合,从而简化了树形结构的处理。

核心思想

组合模式通过将对象和组合对象(即子对象)封装在统一的接口中,使得客户端可以以一致的方式处理这些对象。这样,无论是处理单个对象还是处理由多个对象组成的集合,客户端的操作都不会改变。

组成部分

  • Component(组件): 这是一个接口或抽象类,声明了叶子节点和复合节点的共同操作接口。例如,它可能声明了 add, remove, getChild, 和其他一些操作。

  • Leaf(叶子节点): 叶子节点实现了 Component 接口,并定义了叶子节点特有的行为。叶子节点是树形结构中的末端元素,不能有子节点。

  • Composite(复合节点): 复合节点也实现了 Component 接口,维护了一个子组件的集合,并定义了对这些子组件的操作方法(如 add, remove, getChild)。复合节点可以包含叶子节点或其他复合节点。

UML图

在这里插入图片描述

Java代码

以下是一个简单的示例,展示了如何在 Java 中实现组合模式。这个示例构建了一个文件系统的树形结构,其中包含文件和文件夹(文件夹可以包含其他文件夹和文件)。

import java.util.ArrayList;
import java.util.List;// Component
interface FileSystemComponent {void print(String indent);
}// Leaf
class File implements FileSystemComponent {private String name;public File(String name) {this.name = name;}@Overridepublic void print(String indent) {System.out.println(indent + "File: " + name);}
}// Composite
class Folder implements FileSystemComponent {private String name;private List<FileSystemComponent> children = new ArrayList<>();public Folder(String name) {this.name = name;}public void add(FileSystemComponent component) {children.add(component);}public void remove(FileSystemComponent component) {children.remove(component);}public FileSystemComponent getChild(int index) {return children.get(index);}@Overridepublic void print(String indent) {System.out.println(indent + "Folder: " + name);for (FileSystemComponent child : children) {child.print(indent + "  ");}}
}// Client
public class CompositePatternExample {public static void main(String[] args) {FileSystemComponent file1 = new File("file1.txt");FileSystemComponent file2 = new File("file2.txt");Folder folder1 = new Folder("folder1");Folder folder2 = new Folder("folder2");folder1.add(file1);folder1.add(folder2);folder2.add(file2);Folder rootFolder = new Folder("root");rootFolder.add(folder1);rootFolder.print("");}
}

解释

  • Component(FileSystemComponent): 这是一个接口,定义了所有文件系统组件的公共操作方法 print,用于输出组件信息。

  • Leaf(File): 实现了 FileSystemComponent 接口,表示文件。文件具有一个名称,并且可以输出自身的信息。

  • Composite(Folder): 也实现了 FileSystemComponent 接口,表示文件夹。文件夹可以包含其他文件夹或文件,并且能够递归地打印所有子组件的信息。

优点

  1. 一致的接口: 组合模式提供了一个统一的接口,客户端无需关心对象的具体类型,无论是处理单一对象还是对象组合,使用方式相同。

  2. 易于扩展: 新的叶子节点或复合节点可以很容易地加入现有系统中,而不需要修改现有的代码。

  3. 简化客户端代码: 客户端代码可以用相同的方式处理单个对象和对象组合,简化了操作和维护。

缺点

  1. 设计复杂: 组合模式可能会导致设计复杂,因为需要处理递归结构以及可能需要大量的子类。

  2. 性能开销: 在处理复杂的树形结构时,可能会有较大的性能开销,特别是在树的深度很大时。

使用场景

  • 文件系统: 典型的应用场景,如文件和文件夹的组织结构。
  • 图形用户界面(GUI): GUI 元素如按钮、面板和对话框可以通过组合模式进行管理。
  • 组织结构: 处理公司或团队的组织结构图。

组合模式通过将对象结构建模为树形结构,使得客户端能够以一致的方式处理各种对象,尤其适合处理层次结构问题。


http://www.ppmy.cn/server/118979.html

相关文章

动态规划day35|1049. 最后一块石头的重量 II(等效转换得很巧妙)、494. 目标和(超重要!!背包的本质)、474. 一和零(多维控制)

动态规划day35|1049. 最后一块石头的重量 II、494. 目标和、一和零 1049. 最后一块石头的重量 II494. 目标和474. 一和零 1049. 最后一块石头的重量 II 有一堆石头&#xff0c;用整数数组 stones 表示。其中 stones[i] 表示第 i 块石头的重量。 每一回合&#xff0c;从中选出…

python的基础语法

Python 的基础语法非常简洁明了&#xff0c;适合初学者快速上手。下面我将为你总结几个最重要的基础语法点&#xff0c;帮你快速掌握 Python 的核心概念。让我们从基础开始逐步深入&#xff0c;像刷副本一样一关一关地攻克它们&#xff01; 1. Hello, World! 每一种编程语言的…

spug项目实现代码本地启动步骤

一、spug代码仓库地址: spug: 开源运维平台&#xff1a;面向中小型企业设计的无 Agent的自动化运维平台&#xff0c;整合了主机管理、主机批量执行、主机在线终端、文件在线上传下载、应用发布、任务计划、配置中心、监控、报警等一系列功能。 - Gitee.com 注意&#xff1a;如…

鹰眼降尘系统多少钱

关于鹰眼系统的价格&#xff0c;由于该系统可能涉及多个领域和不同的配置&#xff0c;因此价格范围可能相对较广。以下是朗观视觉小编对鹰眼系统价格的一些分析和说明&#xff1a; 一、价格影响因素 应用领域&#xff1a;鹰眼系统可能应用于不同的领域&#xff0c;如环保降尘、…

Linux中权限和指令

&#x1f4a5;1、Linux基本指令 1.1 mv 指令 mv指令是move的缩写&#xff0c;用来移动或重命名文件、目录&#xff0c;经常用来备份文件或目录。 mv old_name new_name&#xff1a; 重命名文件或目录mv file /path/to/directory&#xff1a; 移动文件到指定目录 roothcss-ecs…

Unity URP APK打包物体不渲染问题

在测试Shader性能的时候&#xff0c;打包到真机上测试是不可少的。但在一次打包APK时安装&#xff0c;打开程序竟然发现本应该生成的物体都不渲染了&#xff0c;但是在Debug的输出UI上确确实实生成了固定数量的物体&#xff0c;而它们的MeshRender却没有任何渲染&#xff0c;但…

安装2024最新版Android Studio 最详细教程(带图展示)

一、安装JDK &#xff08;1&#xff09;首先在除C盘以外的盘建立文件夹&#xff0c;分别保存软件位置&#xff0c;JDK位置与SDK位置&#xff0c; 特别注意&#xff1a;所有文件名中不要出现空格&#xff0c;而且每个文件夹都是为空的状态 这里我是在D盘中操作。 &#xff0…

Spring Boot 项目的 pom.xml 中,groupId、artifactId 等信息要如何定义?——定义规则及案例

文章目录 1. groupId2. artifactId3. version1. 快照版本&#xff08;Snapshot Version&#xff09;2. 最终发布版本&#xff08;Release Version&#xff09;如何设置版本快照版本与发布版本的区别总结什么时候使用 4. name 和 description示例 pom.xml 配置&#xff1a;小结 …