0

0

c++如何实现工厂方法设计模式_c++ 类继承体系与多态对象创建【教程】

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-01-07 12:57:08

|

293人浏览过

|

来源于php中文网

原创

工厂方法模式用于解耦对象创建与使用,核心是用虚函数将new逻辑上提至抽象工厂,避免if-else硬编码子类、编译依赖爆炸及无法统一管理生命周期。

c++如何实现工厂方法设计模式_c++ 类继承体系与多态对象创建【教程】

工厂方法模式在 C++ 中不是靠“教程步骤”堆出来的,而是为了解决「类继承体系下,调用方不依赖具体子类就能创建多态对象」这个实际问题。核心判断标准只有一条:如果你 new 的地方要写 if-else 判断类型再决定 new 哪个子类,那就该用工厂方法了

为什么不能直接 new 子类?

编码 new ConcreteProductA()new ConcreteProductB() 会把业务逻辑和具体实现强耦合。一旦新增子类,所有调用处都要改;单元测试时也无法注入模拟对象;更无法统一控制对象生命周期(比如加对象池、日志、权限检查)。

常见错误现象:

  • 函数里一堆 if (type == "A") { return new ProductA(); } else if (type == "B") { ... }
  • 头文件里必须 #include 所有具体子类,导致编译依赖爆炸
  • 想替换某个产品实现,却要改十几处 new 调用点

工厂方法的最小可行结构

它本质是把「创建逻辑」上提到一个虚函数里,由子类决定实例化谁。关键不是写多少类,而是让基类接口能表达「我要一个产品」,而不用说「我要一个 A 类型的产品」。

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

实操要点:

知元AI
知元AI

AI智能语音聊天 对讲问答 AI绘画 AI写作 AI创作助手工具

下载
  • 定义抽象产品基类 Product(通常含纯虚函数,确保多态行为)
  • 定义抽象工厂基类 Creator,声明虚函数 virtual std::unique_ptr create() = 0;
  • 每个具体工厂(如 ConcreteCreatorA)重写 create(),返回对应具体产品(如 std::make_unique()
  • 业务代码只持有 std::unique_ptr,调用 create() 得到 std::unique_ptr,完全不知道具体类型
class Product {
public:
    virtual ~Product() = default;
    virtual void operation() const = 0;
};

class ConcreteProductA : public Product { public: void operation() const override { / ... / } };

class Creator { public: virtual ~Creator() = default; virtual std::unique_ptr create() = 0; };

class ConcreteCreatorA : public Creator { public: std::unique_ptr create() override { return std::make_unique(); } };

std::unique_ptr 还是 raw pointer?

std::unique_ptr 是现代 C++ 工厂方法的事实标准。它明确所有权转移,避免内存泄漏,且与多态完美兼容。别用裸指针或 std::shared_ptr 当默认选择 —— 前者要手动 delete,后者引入不必要的引用计数开销,除非你真需要共享所有权。

性能与兼容性影响:

  • std::unique_ptr隐式转换std::unique_ptr&&,适合 move 语义传递
  • 若工厂需支持无状态(如单例工厂),可将 create() 设为 static,但此时就退化为简单工厂,失去多态创建能力
  • 不要在工厂内部用 new Product —— 抽象类不能实例化,编译直接报错:error: invalid new-expression of abstract class type 'Product'

工厂方法 vs 简单工厂 vs 抽象工厂

别被名字绕晕。工厂方法解决的是「一个产品族中,不同工厂创建不同产品」的问题。它和简单工厂(一个静态函数分发创建)的区别在于:前者支持运行时切换工厂(比如根据配置加载不同模块),后者只是语法糖;和抽象工厂(创建多个相关产品)的区别在于:前者只管一个产品等级结构,后者管多个(比如 GUI 库中同时创建 Button + Checkbox)。

容易被忽略的点:

  • 工厂类本身也应遵循依赖倒置:业务代码依赖抽象工厂 Creator,而不是任何具体工厂
  • 如果产品构造需要参数,create() 函数可以加参数,但所有子类工厂必须保持签名一致 —— 否则多态失效
  • RTTI(dynamic_cast)不是替代方案。靠类型转换来“事后补救”创建逻辑,说明工厂设计已经失败

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

720

2023.08.22

java多态详细介绍
java多态详细介绍

本专题整合了java多态相关内容,阅读专题下面的文章了解更多详细内容。

15

2025.11.27

java多态详细介绍
java多态详细介绍

本专题整合了java多态相关内容,阅读专题下面的文章了解更多详细内容。

15

2025.11.27

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

185

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

271

2023.10.25

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1005

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

56

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

334

2025.12.29

C++ 高性能计算与并行编程
C++ 高性能计算与并行编程

本专题专注于 C++ 在高性能计算(HPC)与并行编程中的应用,涵盖多线程、并发数据处理、OpenMP、MPI、GPU加速等技术。通过实际案例,帮助开发者掌握 如何利用 C++ 进行大规模数据计算和并行处理,提高程序的执行效率,适应高性能计算与数据密集型应用场景。

5

2026.01.08

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 0.6万人学习

Rust 教程
Rust 教程

共28课时 | 4.2万人学习

Git 教程
Git 教程

共21课时 | 2.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号