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

篇九:组合模式:树形结构的力量

篇九:“组合模式:树形结构的力量”

开始本篇文章之前先推荐一个好用的学习工具,AIRIght,借助于AI助手工具,学习事半功倍。欢迎访问:http://airight.fun/。

另外有2本不错的关于设计模式的资料,分享出来与大家学习参考。
链接:https://pan.baidu.com/s/1RmhQF_o1CdK8U7s5KeILog?pwd=xc6d
提取码:xc6d

设计模式是软件开发中的重要组成部分,组合模式是结构型设计模式中的一种。组合模式旨在将对象组织成树形结构,使得用户可以以统一的方式处理单个对象和组合对象。通过组合模式,我们可以更加灵活地构建复杂的树形结构,从而实现了对象的递归组合。在C++中,组合模式广泛应用于处理树形结构的场景,让我们一起探讨其核心概念和用途,并演示在C++中如何应用组合模式来构建树形结构。

1. 组合模式的核心概念和用途:
组合模式是结构型设计模式,其核心概念在于将对象组织成树形结构,由树根(树的顶层对象)递归组合其子节点(叶子节点或其他组合节点)。组合模式允许用户以统一的方式处理单个对象和组合对象,无需关心具体处理的是哪种类型的对象。

组合模式的用途如下:

  • 构建复杂树形结构:组合模式允许用户以递归的方式构建复杂的树形结构,将对象和组合对象以统一的方式组织起来。
  • 统一处理对象:组合模式允许用户以统一的方式处理单个对象和组合对象,无需区分具体对象类型。

2. 在C++中应用组合模式构建树形结构:

a. 定义抽象组件类:

// Component.h
#include <string>class Component {
public:virtual ~Component() {}virtual void operation() const = 0;virtual void add(Component* component) {}virtual void remove(Component* component) {}virtual Component* getChild(int index) const { return nullptr; }virtual std::string getName() const { return ""; }
};

b. 创建叶子节点类:

// Leaf.h
#include <iostream>
#include "Component.h"class Leaf : public Component {
public:explicit Leaf(std::string name) : name_(std::move(name)) {}void operation() const override {std::cout << "Leaf " << name_ << " operation" << std::endl;}std::string getName() const override {return name_;}private:std::string name_;
};

c. 创建组合节点类:

// Composite.h
#include <iostream>
#include <vector>
#include "Component.h"class Composite : public Component {
public:explicit Composite(std::string name) : name_(std::move(name)) {}void operation() const override {std::cout << "Composite " << name_ << " operation" << std::endl;for (const auto& component : components_) {component->operation();}}void add(Component* component) override {components_.push_back(component);}void remove(Component* component) override {auto it = std::find(components_.begin(), components_.end(), component);if (it != components_.end()) {components_.erase(it);}}Component* getChild(int index) const override {if (index >= 0 && index < components_.size()) {return components_[index];}return nullptr;}std::string getName() const override {return name_;}private:std::string name_;std::vector<Component*> components_;
};

d. 使用组合模式构建树形结构:

// main.cpp
#include "Leaf.h"
#include "Composite.h"int main() {Component* root = new Composite("Root");Component* leaf1 = new Leaf("Leaf1");Component* leaf2 = new Leaf("Leaf2");root->add(leaf1);root->add(leaf2);Component* subComposite = new Composite("SubComposite");Component* leaf3 = new Leaf("Leaf3");subComposite->add(leaf3);root->add(subComposite);root->operation();delete root;delete leaf1;delete leaf2;delete leaf3;delete subComposite;return 0;
}

在上述示例中,我们首先定义了抽象组件类Component,其中包含了对操作的抽象接口和对子节点的增删查操作。然后,我们创建了叶子节点类Leaf,表示树的叶子节点,以及组合节点类Composite,表示树的组合节点。组合节点类中包含了一个std::vector来存储子节点。

main.cpp中,我们创建了树的根节点root,以及两个叶子节点leaf1leaf2。然后,我们将leaf1leaf2添加到根节点root中。接着,我们创建了一个子组合节点subComposite,并将叶子节点leaf3添加到subComposite中。最后,我们将subComposite添加到根节点root中,并调用rootoperation()方法来执行操作。

3. 组合模式的代码解析:

  • 组合模式通过将对象组织成树形结构,实现了对对象的递归组合。树的根节点作为组合节点,其子节点可以是叶子节点或其他组合节点,从而构建了复杂的树形结构。
  • 抽象组件类定义了操作的抽象接口和对子节点的增删查操作,叶子节点类表示树的叶子节点,组合节点类表示树的组合节点。
  • 组合模式允许用户以统一的方式处理单个对象和组合对象,无需关心具体处理的是哪种类型的对象。用户可以通过组合模式以递归的方式构建复杂的树形结构,并统一处理树的所有节点。

**4. 总结:
组合模式是一种非常有用的设计模式,特别适用于构建树形结构或部分整体层次结构的场景。通过使用组合模式,我们可以简化对树形结构的操作,统一处理叶子节点和组合节点,提高代码的可维护性和可扩展性。

在实际开发中,组合模式经常用于处理复杂的对象组织关系。例如,在图形编辑器中,我们可以使用组合模式来处理图形元素的组合。图形元素可以是基本图形如圆形、矩形等,也可以是复杂的组合图形如图形群组。通过组合模式,我们可以以统一的方式处理单个图形元素和图形群组,从而实现图形的递归组合,构建出复杂的图形结构。

另一个例子是在操作系统文件系统中的应用。文件系统可以被组织成树形结构,目录可以包含子目录和文件。使用组合模式,我们可以统一处理目录和文件的操作,无需区分具体的文件和目录类型,从而简化了文件系统的操作。

需要注意的是,组合模式适用于对象组织结构稳定的情况。如果对象组织结构经常发生变化,可能导致频繁的节点增删操作,影响性能。在这种情况下,可以考虑使用其他设计模式来处理动态变化的情况。

总的来说,组合模式是一种强大的设计模式,能够有效地处理树形结构和部分整体层次结构,提高代码的灵活性和可维护性。在C++中,我们可以通过定义抽象组件类和具体组件类,以及创建叶子节点和组合节点来应用组合模式。通过组合模式,我们能够更加灵活地构建复杂的树形结构,实现了对象的递归组合,使得我们可以更好地处理复杂的对象组织关系。

希望本文能够帮助您深入理解组合模式的核心概念和用途,并通过C++的示例代码演示了如何应用组合模式来构建树形结构。在后续的专栏文章中,我们将继续介绍更多设计模式的知识,包括原理、详细介绍、示例代码和代码解析,帮助您深入学习和应用设计模式。

参考文献:

  • Gamma, E., Helm, R., Johnson, R., & Vlissides, J. (1994). Design Patterns: Elements of Reusable Object-Oriented Software. Addison-Wesley Professional.
  • C++ Core Guidelines: https://isocpp.github.io/CppCoreGuidelines/CppCoreGuidelines

感谢您的阅读,欢迎一起探讨,共同进步,推荐大家使用学习助手AIRight来解答学习过程中的问题,访问链接:http://airight.fun/

相关文章:

篇九:组合模式:树形结构的力量

篇九&#xff1a;“组合模式&#xff1a;树形结构的力量” 开始本篇文章之前先推荐一个好用的学习工具&#xff0c;AIRIght&#xff0c;借助于AI助手工具&#xff0c;学习事半功倍。欢迎访问&#xff1a;http://airight.fun/。 另外有2本不错的关于设计模式的资料&#xff0c…...

【注册表】windows系统注册表常用修改方案

文章目录 ◆ 修改IE浏览器打印页面参数设置◆气泡屏幕保护◆彩带屏幕保护程序◆过滤IP(适用于WIN2000)◆禁止显示IE的地址栏◆禁止更改&#xff29;&#xff25;默认的检查(winnt适用)◆允许DHCP(winnt适用)◆局域网自动断开的时间(winnt适用)◆禁止使用“重置WEB设置”◆禁止更…...

ant-design-vue 4.x升级问题-样式丢失问题

[vue] ant-design-vue 4.x升级问题-样式丢失问题 项目环境问题场景解决方案 该文档是在升级ant-design-vue到4.x版本的时候遇到的问题 项目环境 "vue": "^3.3.4", "ant-design-vue": "^4.0.0", "vite": "^4.4.4&quo…...

【果树农药喷洒机器人】Part3:变量喷药系统工作原理介绍

本专栏介绍&#xff1a;免费专栏&#xff0c;持续更新机器人实战项目&#xff0c;欢迎各位订阅关注。 关注我&#xff0c;带你了解更多关于机器人、嵌入式、人工智能等方面的优质文章&#xff01; 文章目录 一、变量喷药系统工作原理二、液压通路设计与控制系统封装2.1液压通路…...

GoogLeNet创新点总结

GoogLeNet是一种深度卷积神经网络架构&#xff0c;于2014年由Google团队提出&#xff0c;是ILSVRC&#xff08;ImageNet Large Scale Visual Recognition Challenge&#xff09;比赛的冠军模型&#xff0c;其创新点主要集中在以下几个方面&#xff1a;   Inception模块&#…...

不同路径1、2、3合集(980. 不同路径 III)

不同路径一 矩形格&#xff0c;左上角 到 右下角。 class Solution {int [] directX new int[]{-1,1,0,0};int [] directY new int[]{0,0,-1,1};int rows;int cols;public int uniquePathsIII(int[][] grid) {if (grid null || grid.length 0 || grid[0].length 0) {ret…...

【云原生】Yaml文件详解

目录 一、YAML 语法格式1.1查看 api 资源版本标签1.2 写一个yaml文件demo1.3 详解k8s中的port 一、YAML 语法格式 Kubernetes 支持 YAML 和 JSON 格式管理资源对象JSON 格式&#xff1a;主要用于 api 接口之间消息的传递YAML格式&#xff1a;用于配置和管理&#xff0c;YAML 是…...

ffmpeg下载安装教程

ffmpeg官网下载地址https://ffmpeg.org/download.html 这里以windows为例,鼠标悬浮到windows图标上,再点击 Windows builds from gyan.dev 或者直接打开 https://www.gyan.dev/ffmpeg/builds/ 下载根据个人需要下载对应版本 解压下载的文件,并复制bin所在目录 新打开一个命令…...

uniapp之当你问起“tab方法触发时eventchange也跟着触发了咋办”时

我相信没有大佬会在这个问题上卡两个小时吧&#xff0c;记下来大家就当看个乐子了。 当时问题就是&#xff0c;点击tab头切换的时候&#xff0c;作为tab滑动事件的eventchange同时触发了&#xff0c;使得接口请求了两次 大概是没睡好&#xff0c;我当时脑子老想着怎么阻止它冒…...

TS 踩坑之路(四)之 Vue3

一、在使用定义默认值withDefaults和defineProps 组合时&#xff0c;默认值设置报错 代码案例 报错信息 不能将类型“{ isBackBtn: false; }”分配给类型“(props: PropsType) > RouteMsgType”。 对象字面量只能指定已知属性&#xff0c;并且“isBackBtn”不在类型“(pro…...

【音视频】edge与chrome在性能上的比较

目录 结论先说 实验 结论 实验机器的cpu配置 用EDGE拉九路​编辑 google拉五路就拉不出来了 资源使用情况 edge报错​编辑 如果服务器端 性能也满 了&#xff0c;就会不回复&#xff1b;验证方式 手动敲 8081&#xff0c;不回应。 结论先说 实验 用chrome先拉九路&#…...

Docker Compose编排部署LNMP服务

目录 安装docker-ce 阿里云镜像加速器 文件 启动 安装docker-ce [rootlocalhost ~]# wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo --2023-08-03 18:34:32-- http://mirrors.aliyun.com/repo/Centos-7.repo 正在解析主机 m…...

git使用(常见用法)

一.下载git git官方下载跳转 安装简单,有手就行 二. git的简单使用 1. 连接远程仓库 #初始化 git init #配置账户 git config --global user.name “输入你的用户名” git config --global user.email “输入你的邮箱” git config --list #--q退出 #配置验证邮箱 ssh-key…...

用例拆分情况考虑方案

文章目录 1、方案一方案概述方案分析(1) 把对应图商地图的逻辑给分离开(2) 要使用命令行的方式执行方法 2、方案二3、最终决定 1、方案一 方案概述 每个图商&#xff08;GD、BD、自建&#xff09;拆分成单独的类 把参数化的几个图商类别拆分成对应的图商类&#xff0c;在每个类…...

一文搞懂IS-IS报文通用格式

报文格式 IS-IS报文是直接封装在数据链路层的帧结构中的。PDU可以分为两个部分&#xff0c;报文头和变长字段部分。其中头部又可分为通用头部和专用头部。对于所有PDU来说&#xff0c;通用报头都是相同的&#xff0c;但专用报头根据PDU类型不同而有所差别。 IS-IS的PDU有4种类…...

位置参数 关键字参数

在Python中&#xff0c;函数参数可以按照位置或关键字来传递。这导致了两种主要的参数类型&#xff1a;位置参数和关键字参数。 位置参数: 这是最常见的参数类型&#xff0c;当我们调用函数时&#xff0c;传递给函数的参数值是按照它们的位置来确定的。例如&#xff0c;def fun…...

【果树农药喷洒机器人】Part5:基于深度相机与分割掩膜的果树冠层体积探测方法

文章目录 一、引言二、树冠体积测量对比方法2.1冠层体积人工测量法2.2冠层体积拟合测量法 三、基于深度相机与分割掩膜探测树冠体积方法3.1像素值与深度值的转换3.2树冠体积视觉探测法3.3实验分析 总结 一、引言 果树靶标探测是实现农药精准喷施的关键环节&#xff0c;本章以果…...

生活小妙招之UE custom Decal

因为这几年大部分时间都在搞美术&#xff0c;所以博客相关的可能会鸽的比较多&#xff0c;阿巴阿巴 https://twitter.com/Tuatara_Games/status/1674034744084905986 之前正好看到一个贴花相关的小技巧&#xff0c;正好做一个记录&#xff0c;也在这个的基础上做一些小的拓展…...

DAY02_Spring—第三方资源配置管理Spring容器Spring注解开发Spring整合Mybatis和Junit

目录 一 第三方资源配置管理1 管理DataSource连接池对象问题导入1.1 管理Druid连接池1.2 管理c3p0连接池 2 加载properties属性文件问题导入2.1 基本用法2.2 配置不加载系统属性2.3 加载properties文件写法 二 Spring容器1 Spring核心容器介绍问题导入1.1 创建容器1.2 获取bean…...

Icon图标有哪些在线设计的工具推荐

虽然icon图标相对较小&#xff0c;但icon图标在设计中非常重要。高质量的icon图标通常可以决定设计工作的质量。高质量的在线生产icon工具可以提高设计师图标设计的效率。此外&#xff0c;优秀的图标设计师还可以让设计师快速开始图标设计工作。本文为您选择了五种在线生成icon…...

浅谈 React Hooks

React Hooks 是 React 16.8 引入的一组 API&#xff0c;用于在函数组件中使用 state 和其他 React 特性&#xff08;例如生命周期方法、context 等&#xff09;。Hooks 通过简洁的函数接口&#xff0c;解决了状态与 UI 的高度解耦&#xff0c;通过函数式编程范式实现更灵活 Rea…...

el-switch文字内置

el-switch文字内置 效果 vue <div style"color:#ffffff;font-size:14px;float:left;margin-bottom:5px;margin-right:5px;">自动加载</div> <el-switch v-model"value" active-color"#3E99FB" inactive-color"#DCDFE6"…...

生成 Git SSH 证书

&#x1f511; 1. ​​生成 SSH 密钥对​​ 在终端&#xff08;Windows 使用 Git Bash&#xff0c;Mac/Linux 使用 Terminal&#xff09;执行命令&#xff1a; ssh-keygen -t rsa -b 4096 -C "your_emailexample.com" ​​参数说明​​&#xff1a; -t rsa&#x…...

Keil 中设置 STM32 Flash 和 RAM 地址详解

文章目录 Keil 中设置 STM32 Flash 和 RAM 地址详解一、Flash 和 RAM 配置界面(Target 选项卡)1. IROM1(用于配置 Flash)2. IRAM1(用于配置 RAM)二、链接器设置界面(Linker 选项卡)1. 勾选“Use Memory Layout from Target Dialog”2. 查看链接器参数(如果没有勾选上面…...

Cloudflare 从 Nginx 到 Pingora:性能、效率与安全的全面升级

在互联网的快速发展中&#xff0c;高性能、高效率和高安全性的网络服务成为了各大互联网基础设施提供商的核心追求。Cloudflare 作为全球领先的互联网安全和基础设施公司&#xff0c;近期做出了一个重大技术决策&#xff1a;弃用长期使用的 Nginx&#xff0c;转而采用其内部开发…...

2025盘古石杯决赛【手机取证】

前言 第三届盘古石杯国际电子数据取证大赛决赛 最后一题没有解出来&#xff0c;实在找不到&#xff0c;希望有大佬教一下我。 还有就会议时间&#xff0c;我感觉不是图片时间&#xff0c;因为在电脑看到是其他时间用老会议系统开的会。 手机取证 1、分析鸿蒙手机检材&#x…...

高防服务器能够抵御哪些网络攻击呢?

高防服务器作为一种有着高度防御能力的服务器&#xff0c;可以帮助网站应对分布式拒绝服务攻击&#xff0c;有效识别和清理一些恶意的网络流量&#xff0c;为用户提供安全且稳定的网络环境&#xff0c;那么&#xff0c;高防服务器一般都可以抵御哪些网络攻击呢&#xff1f;下面…...

Android 之 kotlin 语言学习笔记三(Kotlin-Java 互操作)

参考官方文档&#xff1a;https://developer.android.google.cn/kotlin/interop?hlzh-cn 一、Java&#xff08;供 Kotlin 使用&#xff09; 1、不得使用硬关键字 不要使用 Kotlin 的任何硬关键字作为方法的名称 或字段。允许使用 Kotlin 的软关键字、修饰符关键字和特殊标识…...

Python 包管理器 uv 介绍

Python 包管理器 uv 全面介绍 uv 是由 Astral&#xff08;热门工具 Ruff 的开发者&#xff09;推出的下一代高性能 Python 包管理器和构建工具&#xff0c;用 Rust 编写。它旨在解决传统工具&#xff08;如 pip、virtualenv、pip-tools&#xff09;的性能瓶颈&#xff0c;同时…...

Yolov8 目标检测蒸馏学习记录

yolov8系列模型蒸馏基本流程&#xff0c;代码下载&#xff1a;这里本人提交了一个demo:djdll/Yolov8_Distillation: Yolov8轻量化_蒸馏代码实现 在轻量化模型设计中&#xff0c;**知识蒸馏&#xff08;Knowledge Distillation&#xff09;**被广泛应用&#xff0c;作为提升模型…...