【C++】简单工厂模式

2023年12月6日,周三下午

今天又学习了一次简单工厂模式

每多学习一次,都会加深对设计模式的理解


目录


什么是简单工厂模式

简单工厂模式(Simple Factory Pattern)是一种创建型设计模式,它提供了一种通过使用一个共同的接口来创建不同类型对象的方法。

在简单工厂模式中,有一个工厂类负责创建对象,而不是直接在客户端代码中实例化对象。客户端只需要通过向工厂类发送请求,并传递相应的参数,工厂类就会根据参数的不同来创建具体的对象。

简单工厂模式包含以下几个角色:

  • 工厂类(Factory Class):负责根据客户端的请求创建对象,并将对象返回给客户端。
  • 抽象产品类(Abstract Product Class):定义了产品的共同接口,用于描述具体产品类的共同特征。
  • 具体产品类(Concrete Product Class):实现了抽象产品类的接口,具体产品类是由工厂类创建的对象。

简单工厂模式的优缺点

简单工厂模式的优势在于将对象的创建和使用进行了分离,客户端只需要关心如何使用对象,而无需关心对象的创建过程。这样可以降低代码的耦合性,并提供了一定的灵活性,如果需要新增或修改产品,只需要修改工厂类即可。

然而,简单工厂模式也有一些限制。例如,当需要创建的产品类型较多时,工厂类的代码会变得复杂,违反了开闭原则。此外,简单工厂模式也无法满足创建对象的变化需求,需要借助其他的创建型设计模式,如工厂方法模式或抽象工厂模式。

举例说明

cpp 复制代码
#include <iostream>

// 抽象产品类
class Shape {
public:
  virtual void draw() = 0;
};

// 具体产品类:圆形
class Circle : public Shape {
public:
  void draw() override {
    std::cout << "Draw a circle." << std::endl;
  }
};

// 具体产品类:矩形
class Rectangle : public Shape {
public:
  void draw() override {
    std::cout << "Draw a rectangle." << std::endl;
  }
};

// 工厂类
class ShapeFactory {
public:
  // 创建具体产品对象的方法
  Shape* createShape(const std::string& type) {
    if (type == "circle") {
      return new Circle();
    } else if (type == "rectangle") {
      return new Rectangle();
    } else {
      return nullptr; // 可以根据实际情况返回默认的或者异常处理
    }
  }
};

int main() {
  ShapeFactory factory;
  
  Shape* shape1 = factory.createShape("circle");
  shape1->draw();  // 输出:Draw a circle.

  Shape* shape2 = factory.createShape("rectangle");
  shape2->draw();  // 输出:Draw a rectangle.

  return 0;
}
相关推荐
博客18001 天前
酷宝的使用方法,超好用的免费界面库,C++、MFC可用
c++·mfc·界面库·库来帮·酷宝
郝学胜_神的一滴1 天前
CMake 026:属性体系精讲、四大作用域全解 & 实战代码落地
c++·cmake
众少成多积小致巨2 天前
JNI (Java Native Interface) 技术手册中文参考指南
android·java·c++
clint4566 天前
C++进阶(1)——前景提要
c++
夜悊6 天前
C++代码示例:进制数简单生成工具
c++
郝学胜_神的一滴6 天前
CMake 021: IF 条件判据详诠
c++·cmake
_wyt0017 天前
洛谷 B3930 [GESP202312 五级] 烹饪问题 题解
c++·gesp
玖玥拾7 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
один but you7 天前
constexpr函数
c++
凡人叶枫7 天前
Effective C++ 条款41:了解隐式接口和编译期多态
java·开发语言·c++·effective c++