01_23 种设计模式之《简单工厂模式》

文章目录

一、什么是设计模式

设计模式:在软件研发过程中,经过实战验证,用于解决在特定环境下、重复出现的,特定问题的解决方案,基于面向对象的设计原则:主要是对接口编程

而不是对实现编程、优先使用对象组合而不是继承

二、设计模式类型

23 种设计模式可分为三类:创建型模式、结构型模式、行为模式。

简单工厂模式、单例模式、抽象工厂模式、原型模式、建造者模式(5 种)。

代理模式、外观模式、享元模式、组合模式、装饰器模式、适配器模式、桥接模式(7 种)。

访问者模式、策略模式、模板模式、状态模式、备忘录模式、观察者模式、中介者模式、迭代器模式、解释器模式、责任链模式、命令模式(11 种)

简单工厂模式及应用场景

简单工厂模式主要解决接口选择问题。

Factory(工厂)的核心部分,负责实现创建所有产品的内部逻辑,工厂类可以被外界直接调用,创建所需对象即可

定义抽象产品类和具体产品类

首先,定义一个抽象产品类几个具体产品类。这些类将实现一个共同的接口。

cpp 复制代码
// 抽象产品类
class Product {
public:
    virtual void use() = 0; // 纯虚函数
    virtual ~Product() {}   // 虚析构函数,确保派生类对象能正确析构
};

// 具体产品类A
class ConcreteProductA : public Product {
public:
    void use() override {
        std::cout << "Result of the product A" << std::endl;
    }
};

// 具体产品类B
class ConcreteProductB : public Product {
public:
    void use() override {
        std::cout << "Result of the product B" << std::endl;
    }
};

实现工厂类

接下来,实现一个工厂类,它根据输入参数决定创建哪种产品对象。

cpp 复制代码
// 工厂类
class SimpleFactory {
public:
    static Product* createProduct(const std::string& type) {
        if (type == "A") {
            return new ConcreteProductA();
        } else if (type == "B") {
            return new ConcreteProductB();
        }
        return nullptr;
    }
};

客户端代码

最后,编写客户端代码,使用工厂类创建产品对象。

cpp 复制代码
#include <iostream>
#include <string>

int main() {
    std::string type = "A"; // 假设客户端需要创建产品A
    Product* product = SimpleFactory::createProduct(type);
    if (product != nullptr) {
        product->use();
        delete product; // 记得释放内存
    }

    type = "B"; // 现在客户端需要创建产品B
    product = SimpleFactory::createProduct(type);
    if (product != nullptr) {
        product->use();
        delete product; // 记得释放内存
    }

    return 0;
}

注意事项

扩展性:如果产品类非常多,工厂类可能会变得复杂。在这种情况下,可以考虑使用工厂方法模式或抽象工厂模式。

相关推荐
c++之路1 小时前
Bazel C++ 构建系列文档(三):构建第一个 C++ 项目
开发语言·c++
旖-旎1 小时前
《LeetCode 695 岛屿的最大面积 FloodFill DFS 解法》
c++·算法·力扣·深度优先遍历·floodfill
森G2 小时前
61、信号与槽机制在 TCP 编程中的应用---------网络编程
网络·c++·qt·网络协议·tcp/ip
syagain_zsx2 小时前
STL 之 vector 讲练结合
c++·算法
牛油果子哥q2 小时前
STL set与map底层精讲,红黑树适配原理、有序去重特性、迭代器遍历、API实战与面试核心考点全解
开发语言·数据结构·c++·面试
奇妙方程式3 小时前
2026年第九届GXCPC广西大学生程序设计大赛(热身赛)题解
c++·编程比赛·编程竞赛·gxcpc
Tian_Hang4 小时前
C++原型模式(Protype)
开发语言·c++·算法
FL16238631295 小时前
[cmake]基于C++使用纯opencv部署ppocrv5v6的onnx模型
开发语言·c++·opencv
玖玥拾5 小时前
C/C++ 数据结构(六)链表迭代器与底层
c语言·数据结构·c++·链表·stl库
牛油果子哥q5 小时前
AVL平衡树与红黑树深度精讲对比,平衡因子、四大旋转原理、着色规则、平衡策略、性能差异与面试手撕全解
数据结构·c++·面试