新闻中心

C++如何实现一个组合模式_C++设计模式之将对象组合成树形结构

2025-12-15
浏览次数:
返回列表
组合模式通过统一接口处理整体与部分关系,使用抽象基类定义add、remove和display方法,叶子节点直接实现,容器节点维护子节点列表并递归调用。示例中总公司(Composite)包含分公司(Composite),分公司下挂员工(Leaf),形成树形结构,客户端无需区分单个或组合对象,实现透明操作。

c++如何实现一个组合模式_c++设计模式之将对象组合成树形结构

组合模式(Composite Pattern)用来将对象组织成树形结构,表示“整体-部分”关系。它让客户端可以统一处理单个对象和组合对象。在C++中,通过抽象基类、父节点持有子节点的容器来实现。

定义组件接口

所有对象,无论是叶子还是复合节点,都应继承自同一个基类。这个基类提供统一的操作接口,比如 addremovedisplay

  • 使用纯虚函数确保派生类必须实现对应方法
  • 父类指针可以指向叶子或容器,实现多态调用
class Component {
public:
    virtual ~Component() = default;
    virtual void add(Component* c) {}
    virtual void remove(Component* c) {}
    virtual void display(int depth) const = 0;
};

实现叶子节点和容器节点

叶子节点不包含子节点,因此 addremove 不做任何操作。容器节点维护一个子节点列表,并在 display 时递归调用子节点。

class Leaf : public Component {
    std::string name;
public:
    explicit Leaf(const std::string& n) : name(n) {}

    void display(int depth) const override {
        std::cout << std::string(depth, '-') << " " << name << std::endl;
    }
};

class Composite : public Component {
    std::string name;
    std::vector<Component*> children;
public:
    explicit Composite(const std::string& n) : name(n) {}

    void add(Component* c) override {
        children.push_back(c);
    }

    void remove(Component* c) override {
        children.erase(
            std::remove(children.begin(), children.end(), c),
            children.end()
        );
    }

    void display(int depth) const override {
        std::cout << std::string(depth, '-') << " " << name << std::endl;
        for (const auto& child : children) {
            child->display(depth + 2);
        }
    }
};

使用示例

构建一个公司部门结构:总公司下设多个分公司,分公司下有具体员工(叶子)。

立即学习“C++免费学习笔记(深入)”;

风车Ai翻译 风车Ai翻译

跨境电商必备AI翻译工具

风车Ai翻译 407 查看详情 风车Ai翻译
int main() {
    Composite root("总公司");
    Leaf emp1("财务人员");
    Leaf emp2("技术人员");

    Composite subBranch("上海分公司");
    subBranch.add(&emp1);
    subBranch.add(&emp2);

    root.add(&subBranch);
    root.display(0);  // 输出层级结构
    return 0;
}

输出:

  • 总公司
  • 上海分公司
  • 财务人员
  • 技术人员

这样就实现了树形结构的统一操作。添加或删除节点对客户端透明,无需区分是单一对象还是组合。

基本上就这些。只要接口设计清晰,父子关系管理得当,组合模式能有效简化复杂结构的处理逻辑。

以上就是C++如何实现一个组合模式_C++设计模式之将对象组合成树形结构的详细内容,更多请关注其它相关文章!


# c++  # seo服务商推荐  # 边缘  # 财务人员  # 尼克  # 多态  # 技术人员  # 客户端  # 如何实现  # 游戏开发  # 递归  # 上海  # ai  # 手机关键词排名点击率  # 江苏正规seo推广首页  # 宁夏seo关键词排名优化软件  # 威士忌营销推广策划案  # 长沙优化推广营销  # 白城关键词优化排名公司  # 德阳品牌网站建设优化  # 营销宝的推广方案有哪些  # 南京网站收录优化软件 


相关栏目: 【 科技资讯46185 】 【 网络学院92790


相关推荐: 照顾宝贝2小游戏免费秒玩入口  J*a递归快速排序中静态变量的状态管理与陷阱  html怎么运行外部js文件中的函数_运html外js文件函数法【技巧】  必由学网页版入口 必由学官方平台直接访问  深入理解与实现最大堆的Heapify过程:常见错误与修正  Pandas DataFrame 高效批量赋值:告别循环与笛卡尔积误区  Win11怎么隐藏桌面图标 Win11一键隐藏所有桌面元素及恢复显示  C++如何进行游戏物理模拟_使用Box2D库为C++游戏添加2D物理效果  Safari怎么安装扩展程序 浏览器插件安装与管理方法【详解】  J*aScript数组对象转换:按指定键分组与值收集  58动漫网在线官方网 58动漫网正版动漫入口网址  QQ邮箱网页版入口页面 QQ邮箱在线登录入口官网  从J*aScript对象中精确提取指定属性的教程  夸克浏览器网页版最新地址 夸克浏览器官方入口合集  MinIO大规模对象列表性能瓶颈深度解析与外部元数据管理策略  qq游戏网页版直接玩_qq游戏免下载快速入口  如何使用纯J*aScript判断Input元素是否在特定类容器内  微信网页版登录教程_微信网页版登录入口在哪  在Socket.IO连接中实现Access Token自动更新与动态重连  J*aScript Promise链中如何正确终止后续.then执行并处理错误  C++如何实现一个智能指针_手动实现C++ shared_ptr的引用计数功能  win11如何加载ICC颜色配置文件 Win11校色文件安装与显示器色彩管理【指南】  如何在低配置电脑上搭建轻量级J*a环境_占用更小的环境选择技巧  Win10双系统截图高效法 截屏快捷键速记【技巧】  一加 Nord 5 隐私权限异常_一加 Nord 5 系统安全优化  解决移动端滚动问题的overflow属性应用指南  Golang如何实现容器化日志收集与分析_Golang容器日志收集分析方法  Sublime Text怎么显示空格和制表符_Sublime显示不可见字符设置  steam官方入口大全 steam账号注册及操作指南  如何在J*a中使用Locale处理多语言环境  千牛数据看板网页版_千牛数据看板网页版访问方法  Win10自动更新怎么关闭 Win10永久关闭系统更新的两种方法【终极版】  BetterDiscord插件中安全更新用户简介的实践指南  Excel中VLOOKUP的第四个参数是干什么用的_Excel VLOOKUP第四参数作用解析  蛙漫官网漫画入口地址_蛙漫在线畅读无广告弹窗  Win11如何开启讲述人功能 Win11屏幕阅读器(讲述人)开启与关闭【教程】  Win10快速启动功能利弊分析 Win10开启或关闭快速启动教程【技巧】  Animex动漫社网入口地址 Animex动漫社网正版在线入口  Win10磁盘清理工具在哪 Win10打开并使用磁盘清理【教程】  C++如何比较两个字符串_C++ string compare函数与操作符对比  拼多多赚钱渠道_拼多多收益来源  PostgreSQL海量数据高效导入策略:Python与Django实践指南  漫蛙漫画官方首页 漫蛙2漫画在线阅读入口  UC浏览器官网入口2025最新 UC浏览器网页版正式地址  qq游戏大厅官方下载_qq游戏免费下载安装入口  蛙漫限时开放最深处链接_蛙漫全站漫画会员同款秒开地址  小红书网页版入口链接分享 小红书官网直接进  解决Python单元测试中Mock异常方法调用计数为零的问题  内存检查:在VS Code中调试C++时的内存视图  在J*a中如何开发在线活动报名与管理系统_活动报名管理项目实战解析 

搜索