Golang学习笔记_34——组合模式

Golang学习笔记_31——原型模式
Golang学习笔记_32——适配器模式
Golang学习笔记_33——桥接模式


文章目录

    • 一、核心概念
      • 1. 定义
      • 2. 解决的问题
      • 3. 核心角色
      • 4. 类图
    • 二、特点分析
    • 三、适用场景
      • 1. 文件系统
      • 2. 图形界面
      • 3. 组织架构
    • 四、代码示例(Go语言)
    • 五、高级应用
      • 1. 递归统计
      • 2. 组合模式 + 访问者模式
    • 六、与其他模式对比
    • 七、总结


一、核心概念

1. 定义

组合模式(Composite Pattern)是一种结构型设计模式,通过将对象组织成树形结构来表示“部分-整体”的层次关系,使客户端可以统一处理单个对象和组合对象

2. 解决的问题

  • 树形结构表示:需要处理具有层级关系的对象(如文件系统、组织架构)
  • 统一操作接口:消除客户端对叶子节点和组合节点的差异感知
  • 递归遍历需求:需要递归处理嵌套结构(如计算文件夹总大小)

3. 核心角色

  1. Component(抽象组件)
    定义所有对象的通用接口,声明管理子组件的方法(如Add()Remove())和业务方法(如Display()

  2. Leaf(叶子节点)
    树形结构的末端节点,没有子节点,实现具体业务逻辑

  3. Composite(组合节点)
    包含子节点的容器,实现组件接口并管理子组件集合

4. 类图

组合模式类图
示例类图

二、特点分析

优点

  1. 统一接口
    客户端无需区分叶子节点和组合节点,简化调用逻辑

  2. 灵活扩展
    新增组件类型无需修改现有代码,符合开闭原则

  3. 层次清晰
    天然支持树形结构表示,便于处理递归操作

缺点

  1. 设计复杂度高
    需要定义抽象接口并处理递归逻辑,增加实现难度

  2. 类型限制困难
    难以约束容器节点只能包含特定类型子组件

三、适用场景

1. 文件系统

  • 叶子节点:文件
  • 组合节点:文件夹(可包含文件/子文件夹)
  • 操作:递归计算总大小、展示目录结构

2. 图形界面

  • 叶子节点:按钮、文本框
  • 组合节点:面板、窗口
  • 操作:统一渲染、事件处理

3. 组织架构

  • 叶子节点:员工
  • 组合节点:部门
  • 操作:统计总人数、打印层级关系

四、代码示例(Go语言)

package compositedemo

import "fmt"

// Component 接口
type Component interface {
   Display(indent string)
}

// Leaf 叶子节点
type File struct {
   Name string
}

func (l *File) Display(indent string) {
   println(indent + l.Name)
}

// Directory 组合节点
type Directory struct {
   Name      string
   Component []Component
}

func (c *Directory) Display(indent string) {
   println(indent + c.Name)
   for _, component := range c.Component {
      component.Display(indent + indent)
   }
}

func (c *Directory) Add(component Component) {
   c.Component = append(c.Component, component)
}

func (c *Directory) Remove(component Component) {
   for i, v := range c.Component {
      if v == component {
         c.Component = append(c.Component[:i], c.Component[i+1:]...)
      }
   }
}

func test() {
   root := &Directory{Name: "root"}
   directory := &Directory{Name: "directory"}

   file1 := &File{Name: "file1"}
   file2 := &File{Name: "file2"}

   root.Add(directory)
   directory.Add(file1)
   directory.Add(file2)
   root.Display("--")
   fmt.Println("==========================================")
   directory.Display("**")
}

=== RUN   Test_test
--root
----directory
--------file1
--------file2
==========================================
**directory
****file1
****file2
--- PASS: Test_test (0.00s)
PASS

五、高级应用

1. 递归统计

// 在Component接口添加方法
type FileSystemComponent interface {
    Size() int
}

// File实现
func (f *File) Size() int {
    return 1024 // 假设固定大小
}

// Directory实现
func (d *Directory) Size() int {
    total := 0
    for _, child := range d.children {
        total += child.Size()
    }
    return total
}

2. 组合模式 + 访问者模式

通过访问者模式实现更复杂的树形结构操作(如格式转换、权限检查)

六、与其他模式对比

模式核心目标关键区别
装饰器动态添加功能通过嵌套包装扩展功能
适配器接口转换解决接口不兼容问题
迭代器遍历集合元素专注于遍历算法实现

七、总结

组合模式通过树形结构统一接口,有效解决了以下问题:

  1. 层次结构表示:天然适合文件系统、组织架构等场景
  2. 递归操作简化:通过统一接口实现递归遍历
  3. 扩展性提升:新增组件类型不影响现有结构

在Go语言中实现时需注意:

  • 通过接口实现多态特性
  • 使用切片管理子组件集合
  • 谨慎处理叶子节点的无效方法(如Add()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/972053.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

vue+elementplus创建初始化安装

项目创建初始化 D:\Tool\mysql\education_vue 这个路径下cmd 或打开vscode,把项目丢进code中打开 安装element plus Container 布局容器 | Element Plus npm install element-plus --save 把项目初始文件Homeview AboutView删了,Router index.js中删一…

SQL 优化工具使用之 explain 详解

一、导读 对于大部分开发人员来说,平常接触的无非就是增删改查这些基本操作,创建存储过程,视图等等都是 DBA 该干的活,但是想要把这些基本操作写的近乎完美也是一件难事。 而 explain 显示了 MySQL 如何使用索引来处理 select 语…

仿 Sora 之形,借物理模拟之技绘视频之彩

来自麻省理工学院、斯坦福大学、哥伦比亚大学以及康奈尔大学的研究人员携手开源了一款创新的3D交互视频模型——PhysDreamer(以下简称“PD”)。PD与OpenAI旗下的Sora相似,能够借助物理模拟技术来生成视频,这意味着PD所生成的视频蕴…

Python的顺序结构和循环结构

文章目录 一、条件语句(1)条件语句的定义(2)条件语句的语法(a)单分支 if(b)双分支 if-else(c)多分支 if-elif-elif-...-else (3)注意事…

04 redis数据类型

文章目录 redis数据类型string类型hash类型list类型set类型zset类型 (sortedset)通用命令 redis数据类型 官方命令::http://www.redis.cn/commands.html Redis 中存储数据是通过 key-value 格式存储数据的,其中 val…

AutoGen:玩转多智能体团队协作 (Teams)

👉👉👉本人承接各类AI相关应用开发项目(包括但不限于大模型微调、RAG、AI智能体、NLP、机器学习算法、运筹优化算法、数据分析EDA等) !!!👉👉👉 有意愿请私信!!! AutoGen 的 AgentChat 模块为我们提供了强大…

Python PyCharm DeepSeek接入

Python PyCharm DeepSeek接入 创建API key 首先进入DeepSeek官网,https://www.deepseek.com/ 点击左侧“API Keys”,创建API key,输出名称为“AI” 点击“创建",将API key保存,复制在其它地方。 在PyCharm中下…

分享8款AI生成PPT的工具!含测评

随着人工智能技术的飞速进步,制作PPT变得愈发便捷,仅需输入主题指令,便能在瞬间获得一份完整的演示文稿。尤其在制作篇幅较长的PPT时,手动编写每一页内容并设计格式和排版,不仅效率低下,而且耗时耗力。 本…

50页PDF|数字化转型成熟度模型与评估(附下载)

一、前言 这份报告依据GBT 43439-2023标准,详细介绍了数字化转型的成熟度模型和评估方法。报告将成熟度分为五个等级,从一级的基础转型意识,到五级的基于数据的生态价值构建与创新,涵盖了组织、技术、数据、资源、数字化运营等多…

aistdio部署deepseek-r1纯教程

前言 笔者电脑未扩容,想玩玩本地化的deepseek,苦于👇久矣, 想到之前老师介绍的百度云平台飞桨AI Studio星河社区-人工智能学习与实训社区 于是就开始尝试部署终端版deepseek. 一、新建项目 1.打开飞桨网站,创建not…

实现动态翻转时钟效果的 HTML、CSS 和 JavaScript,附源码

实现动态翻转时钟效果的 HTML、CSS 和 JavaScript 在现代网页设计中,动画效果可以极大地增强用户体验。本文将介绍如何利用 HTML、CSS 和 JavaScript 创建一个动态翻转时钟的效果,模拟经典机械翻页时钟的视觉效果。我们将通过详细的步骤讲解如何实现时钟…

RagFlow+Ollama 构建RAG私有化知识库

RagFlowOllama 构建RAG私有化知识库 关于RAG一、什么是RAGFlow一、RAGFlow 安装配置测服已有服务: mysql、redis、elasticsearch 二、RAGFlow 配置 ollama:本地运行大型语言模型的工具软件。用户可以轻松下载、运行和管理各种开源 LLM。降低使用门槛&…

JavaScript(JS)

介绍 JavaScript(简称:JS)是一门跨平台、面向对象的脚本语言。是用来控制网页行为的,它能使网页可交互 JavaScript 和Java 是完全不同的语言,不论是概念还是设计。但是基础语法类似 JS引入方式 内部脚本:将JS代码定义在HTML页面中 JavaScript代码…

LLM 架构

LLM 分类 : 自编码模型 (encoder) : 代表模型 : BERT自回归模型 (decoder) : 代表模型 : GPT序列到序列模型 (encoder-decoder) : 代表模型 : T5 自编码模型 (AutoEncoder model , AE) 代表模型 : BERT (Bidirectional Encoder Representation from Transformers)特点 : Enc…

剑指 Offer II 023. 两个链表的第一个重合节点

comments: true edit_url: https://github.com/doocs/leetcode/edit/main/lcof2/%E5%89%91%E6%8C%87%20Offer%20II%20023.%20%E4%B8%A4%E4%B8%AA%E9%93%BE%E8%A1%A8%E7%9A%84%E7%AC%AC%E4%B8%80%E4%B8%AA%E9%87%8D%E5%90%88%E8%8A%82%E7%82%B9/README.md 剑指 Offer II 023. 两…

【git-hub项目:YOLOs-CPP】本地实现04:项目简化

项目跑通之后,我们常常还需要对我们没有用到的任何内容进行删除,以简化项目体积,也便于我们阅读和后续部署。如何实现呢?本篇博客教会大家实现! 项目一键下载【⬇️⬇️⬇️】: 精简后:【GitHub跑通项目:YOLOs-CPP】+【计算机视觉】+【YOLOv11模型】+【windows+Cpp+ONN…

R语言用逻辑回归贝叶斯层次对本垒打数据与心脏移植数据后验预测检验模拟推断及先验影响分析|附数据代码...

全文链接:https://tecdat.cn/?p40152 在统计学领域中,层次建模是一种极为强大且实用的工具。它能够巧妙地处理复杂的数据结构,通过分层的方式对数据进行建模。在贝叶斯统计的框架内,层次建模优势尽显,其可以有效地融合…

解锁机器学习核心算法 | 随机森林算法:机器学习的超强武器

一、引言 在机器学习的广阔领域中,算法的选择犹如为一场冒险挑选趁手的武器,至关重要。面对海量的数据和复杂的任务,合适的算法能够化繁为简,精准地挖掘出数据背后隐藏的模式与价值。机器学习领域有十大核心算法,而随…

网络工程师 (43)IP数据报

前言 IP数据报是互联网传输控制协议(Internet Protocol,IP)的数据报格式,由首部和数据两部分组成。 一、首部 IP数据报的首部是控制部分,包含了数据报传输和处理所需的各种信息。首部可以分为固定部分和可变部分。 固定…

部署k8s 集群1.26.0(containerd方式)

随着k8s版本逐步更新,在不支持docker环境的情况下,需要使用containerd方式作为容器引擎。为了更好的个人学习使用,需要重新部署一套1.26.0版本的k8s集群,并且使用containerd方式作为容器引擎,版本为1.6.33。在部署过程…