C++工厂方法模式 对象创建接口封装

工厂方法模式通过虚函数将对象创建延迟到子类,实现解耦;C++中以抽象工厂定义接口,具体工厂创建具体产品,客户端仅依赖抽象,符合开闭原则,便于扩展与维护。

c++工厂方法模式 对象创建接口封装

工厂方法模式是一种创建型设计模式,它把对象的创建过程封装到子类中,让父类不依赖具体对象的类型。在C++中,通过虚函数定义创建对象的接口,由派生类决定实例化哪个类,从而实现对象创建的解耦。

工厂方法模式的核心思想

定义一个用于创建对象的接口,但让子类决定实例化哪一个类。工厂方法让类的实例化推迟到子类。

关键点:

有一个抽象工厂基类,声明一个创建对象的虚函数每个具体工厂继承基类,实现自己的对象创建逻辑客户端代码只依赖抽象接口,不关心具体类型

基本实现结构

以生产不同类型的“产品”为例:

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

#include #include 

// 产品抽象基类class Product {public:virtual ~Product() = default;virtual void use() const = 0;};

// 具体产品Aclass ConcreteProductA : public Product {public:void use() const override {std::cout << "使用产品 An";}};

// 具体产品Bclass ConcreteProductB : public Product {public:void use() const override {std::cout << "使用产品 Bn";}};

// 工厂基类 - 定义创建产品的接口class Factory {public:virtual ~Factory() = default;virtual std::unique_ptr createProduct() const = 0;};

// 具体工厂A - 创建产品Aclass ConcreteFactoryA : public Factory {public:std::unique_ptr createProduct() const override {return std::make_unique();}};

// 具体工厂B - 创建产品Bclass ConcreteFactoryB : public Factory {public:std::unique_ptr createProduct() const override {return std::make_unique();}};

使用示例

客户端通过工厂接口创建对象,无需知道具体类名:

int main() {    // 可以根据配置或条件选择工厂    std::unique_ptr factory;
// 假设条件判断使用哪种工厂bool useTypeA = true;if (useTypeA) {    factory = std::make_unique();} else {    factory = std::make_unique();}// 创建产品auto product = factory->createProduct();product->use();  // 输出:使用产品 Areturn 0;

}

优势与适用场景

工厂方法模式在C++中特别适合以下情况:

避免在代码中写死 new 操作:将对象创建集中管理扩展性好:新增产品类型时,只需添加新的工厂类,不修改已有代码符合开闭原则:对扩展开放,对修改关闭解耦客户端与具体类:客户端只依赖抽象接口

基本上就这些。工厂方法模式用虚函数把对象创建封装起来,让程序更灵活,也更容易维护。不复杂但容易忽略细节,比如记得把析构函数设为虚函数,避免资源泄漏。

以上就是C++工厂方法模式 对象创建接口封装的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1473016.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月18日 20:05:16
下一篇 2025年12月18日 20:05:19

相关推荐

  • C++联合体类型双关 二进制数据解释方法

    联合体类型双关通过共享内存实现不同数据类型的灵活解释,如将float写入联合体后以int读取其二进制表示,但需注意字节序、未定义行为等风险;推荐使用std::memcpy替代以提升安全性,并在网络编程、图像处理等场景中结合字节序转换函数确保可移植性。 C++联合体允许你使用相同的内存位置存储不同的数…

    2025年12月18日
    000
  • C++ array容器使用 固定大小数组替代

    std::array 是现代 C++ 中替代 C 风格数组的首选,它在保持栈上分配和零开销的前提下,提供类型安全、边界检查、标准容器接口和值语义。其大小在编译期确定,支持 begin()/end()、size()、at() 安全访问、data() 获取底层指针,并可与 STL 算法无缝集成。相比 C…

    2025年12月18日
    000
  • C++文本文件打开 ifstream基本用法示例

    C++中使用ifstream打开文本文件需创建对象并检查是否成功打开,常用方法是在构造函数中传入路径或调用open(),随后用is_open()验证状态;读取时推荐getline逐行处理,大文件需关注内存与效率;处理UTF-8等编码时,ifstream仅读取字节流,需确保环境编码一致或借助第三方库转…

    2025年12月18日
    000
  • C++标准库算法优化 自定义谓词加速

    合理优化C++谓词函数可显著提升算法性能:使用常量引用避免拷贝、inline减少调用开销、优先选用Lambda或函数对象以利于编译器优化,并将不变计算移出谓词外部以减少重复开销。 在使用C++标准库算法时,自定义谓词是实现灵活逻辑的关键。但若设计不当,可能成为性能瓶颈。合理优化谓词函数,能显著提升算…

    2025年12月18日
    000
  • C++数组类成员 静态动态数组成员管理

    答案:静态数组在类中声明时固定大小,内存随对象创建自动分配;动态数组通过指针声明,需手动管理内存分配与释放,防止内存泄漏。 在C++中,类的成员可以是数组,这类数组成员分为静态数组(固定大小)和动态数组(运行时分配)。合理管理这两类数组成员对程序的稳定性与资源利用至关重要。 静态数组成员 静态数组成…

    2025年12月18日
    000
  • C++游戏开发环境 OpenGL库安装指南

    答案:配置OpenGL开发环境需根据平台安装编译器、GLAD加载库并链接OpenGL库。Windows使用Visual Studio或MinGW,下载GLAD头文件和源码,链接opengl32.lib;macOS通过Xcode集成OpenGL.framework;Linux安装Mesa库并链接-lG…

    2025年12月18日
    000
  • C++模板参数类型 非类型模板参数应用

    非类型模板参数允许在编译期传递值(如整数、指针、C++20起支持浮点数和字面类类型),用于生成特定代码,提升性能与安全性。它避免运行时开销,实现栈上固定大小数组(如std::array)、编译期检查、常量传播和零开销抽象。C++20前限制类型为整型、枚举、指针等,因浮点精度和字符串地址不确定性影响模…

    2025年12月18日
    000
  • C++内存模型教育 学习资源与教学方法

    C++内存模型的核心在于定义多线程下操作的可见性与顺序性,其关键概念包括Happens-Before关系、内存顺序(如seq_cst、acquire-release、relaxed)以及数据竞争的规避;通过共享计数器、生产者-消费者模型、双重检查锁定等实践案例,结合Thread Sanitizer、…

    2025年12月18日
    000
  • C++迷宫生成算法 深度优先随机生成

    答案:使用DFS结合随机性生成迷宫,从起点开始标记访问,随机打乱方向顺序,打通相邻未访问格子间的墙并递归探索,最终形成连通无环的迷宫结构。 用深度优先搜索(DFS)结合随机性来生成迷宫,是一种常见且效果不错的算法。核心思路是模拟“回溯探索”的过程,从起点出发,随机选择未访问的方向前进,打通墙壁,直到…

    2025年12月18日
    000
  • C++栈溢出预防 递归深度与局部变量控制

    栈溢出主因是递归过深和局部变量过大,可通过限制递归深度、减少栈内存占用、使用堆分配和迭代替代递归来预防,尤其在嵌入式系统中更需注意栈大小控制。 栈溢出在C++中常见于递归调用过深或局部变量占用空间过大。这类问题在运行时可能引发程序崩溃,尤其在嵌入式系统或深度算法中更需警惕。预防的关键在于控制递归深度…

    2025年12月18日
    000
  • C++依赖注入实现 松耦合组件设计方法

    C++中依赖注入通过构造函数、Setter和接口注入实现,推荐使用构造函数注入结合智能指针与接口抽象,实现松耦合、易测试的系统设计。 在C++中实现依赖注入(Dependency Injection, DI)是构建松耦合、可测试、可维护组件系统的重要手段。依赖注入的核心思想是将对象所依赖的其他对象从…

    2025年12月18日
    000
  • C++单词测试程序 文件读写评分功能

    答案:程序从words.txt读取单词,用户输入中文意思答题,系统自动评分并保存结果到result.txt。 做一个C++单词测试程序,核心功能包括从文件读取单词、用户答题、自动评分并将结果写入文件,整个流程可以拆解为几个关键部分来实现。下面是一个结构清晰、功能完整的示例程序,包含文件读写和评分功能…

    2025年12月18日
    000
  • C++折叠表达式 变参模板简化技巧

    C++17引入的折叠表达式简化了变参模板的使用,通过一元或二元操作符直接作用于参数包,避免了传统递归写法的冗长与复杂,支持求和、打印、逻辑判断等场景,显著提升了代码可读性和编写效率。 C++17引入的折叠表达式(Fold Expressions)无疑是变参模板(Variadic Templates)…

    2025年12月18日 好文分享
    000
  • C++自定义内存分配器 重载new运算符实例

    通过重载new和delete,MyClass使用自定义内存池管理对象分配,提升性能并监控内存使用,数组操作则回退到全局分配器。 在C++中,通过重载 new 和 delete 运算符,可以实现自定义内存分配行为。这在需要优化性能、监控内存使用或使用特定内存池的场景中非常有用。下面是一个简单的实例,展…

    2025年12月18日
    000
  • C++物理模拟器 刚体运动模拟实现

    刚体运动模拟器通过牛顿力学更新物体状态。1. 定义包含位置、速度、受力、质量、旋转等属性的刚体结构;2. 每帧用半隐式欧拉法积分:计算加速度a=F/m,更新速度与位置,同步处理角加速度α=τ/I、角速度与角度;3. 施加重力并清零累积力;4. 添加地面碰撞检测,限制位置并反向速度实现弹跳;5. 主循…

    2025年12月18日
    000
  • C++静态成员怎么用 类成员与类方法特性

    静态成员属于类而非对象,所有实例共享同一份数据,生命周期贯穿整个程序运行期。声明时在类内用static关键字,定义时需在类外初始化且不加static。静态成员函数无this指针,只能访问静态成员,适用于工具函数、计数器、工厂方法等与类相关但不依赖实例的场景。非静态成员则属于对象实例,各有独立副本,依…

    2025年12月18日
    000
  • C++虚函数表机制 动态绑定实现原理

    虚函数表(vtable)是C++实现多态的核心机制,编译器为含虚函数的类生成vtable,对象通过vptr指向对应类的vtable,运行时通过vptr查找函数地址实现动态绑定,构造派生类时vptr先指基类再更新为派生类,因此构造函数中调用虚函数不产生多态,且虚函数存在性能与空间开销,静态函数和构造函…

    2025年12月18日
    000
  • C++动态数组扩容 自定义扩容策略实现

    动态数组扩容通过调整容量平衡性能与内存,常见策略有倍增、线性及1.5倍增长,结合函数指针可灵活切换,提升特定场景下的效率表现。 在C++中,动态数组扩容是实现类似 std::vector 功能的核心机制。当现有容量不足以容纳新元素时,需要重新分配更大的内存空间,并将原有数据迁移过去。自定义扩容策略可…

    2025年12月18日
    000
  • C++责任链模式 请求处理链实现

    责任链模式通过链式结构将请求传递给多个处理器,实现解耦与灵活扩展。1. 定义抽象处理器基类Handler,包含处理请求方法和指向下一处理器的智能指针;2. 创建具体处理器LowLevelHandler、MidLevelHandler、HighLevelHandler,分别处理不同级别请求,若无法处理…

    2025年12月18日
    000
  • C++析构函数调用 资源释放时机分析

    析构函数在对象生命周期结束时自动释放资源,调用时机取决于存储类型:局部对象在离开作用域时调用,全局或静态对象在程序结束时调用,动态对象需显式调用delete触发;成员对象析构顺序与其声明顺序相反,基类析构函数最后调用;析构函数中抛出异常可能导致程序终止,应避免;智能指针如unique_ptr和sha…

    2025年12月18日
    000

发表回复

登录后才能评论
关注微信