工厂方法模式通过子类决定实例化类,实现创建与使用的解耦。示例中定义Shape产品接口及Circle、Rectangle具体产品,配合ShapeFactory工厂接口和CircleFactory、RectangleFactory具体工厂,实现图形对象的灵活创建。main函数演示通过不同工厂生成对应图形并调用draw方法。建议使用智能指针管理内存,提升安全性,并可结合注册机制实现按名称创建对象,适用于需动态扩展产品的场景。

工厂设计模式用于将对象的创建过程封装起来,让子类决定实例化哪一个类。C++中常见的工厂模式有简单工厂、工厂方法和抽象工厂。下面以工厂方法模式为例,展示一个清晰、实用的实现方式。
1. 工厂方法模式结构说明
工厂方法模式定义一个创建对象的接口,但由子类决定要实例化的类是哪一个。这样把实例化操作推迟到子类。
主要角色:
- Product(产品):定义产品的接口。
- ConcreteProduct(具体产品):实现 Product 接口的具体类。
- Factory(工厂):声明创建产品对象的方法。
- ConcreteFactory(具体工厂):实现工厂方法,返回一个具体产品实例。
2. C++ 实现示例
假设我们要生产不同类型的图形(如圆形、矩形),通过工厂来创建。
立即学习“C++免费学习笔记(深入)”;

中国首个对标ChatGPT的双千亿级大语言模型
115
查看详情
// Product 抽象基类
class Shape {
public:
virtual void draw() = 0;
virtual ~Shape() = default;
};
// 具体产品类
class Circle : public Shape {
public:
void draw() override {
std::cout << “绘制圆形” << std::endl;
}
};
class Rectangle : public Shape {
public:
void draw() override {
std::cout << “绘制矩形” << std::endl;
}
};
// 工厂基类
class ShapeFactory {
public:
virtual Shape* createShape() = 0;
virtual ~ShapeFactory() = default;
};
// 具体工厂类
class CircleFactory : public ShapeFactory {
public:
Shape* createShape() override {
return new Circle();
}
};
class RectangleFactory : public ShapeFactory {
public:
Shape* createShape() override {
return new Rectangle();
}
};
3. 使用方式
通过具体工厂创建对象,调用其行为:
int main() {
// 创建圆形工厂并生成对象
ShapeFactory factory = new CircleFactory();
Shape shape = factory->createShape();
shape->draw(); // 输出:绘制圆形
// 切换为矩形工厂 delete factory; delete shape; factory = new RectangleFactory(); shape = factory->createShape(); shape->draw(); // 输出:绘制矩形 // 清理资源 delete factory; delete shape; return 0;
}
4. 改进建议与注意事项
上面示例使用了原始指针和 new/delete,实际项目中可结合智能指针提升安全性:
- 返回 std::unique_ptr<Shape> 避免内存泄漏。
- 工厂方法可以配合注册机制实现“根据字符串创建对象”,比如 map 存储类型名到创建函数。
- 若产品种类固定,也可用简单工厂 + switch 实现,更简洁。
基本上就这些。工厂模式的核心是解耦对象的使用和创建,适合需要灵活扩展产品类型的场景。
大家都在看:
C++与AI部署:ONNX Runtime集成全解析
c++中怎么把整数转换成二进制字符串_c++整数转二进制方法
C++20的std::format库怎么用_C++字符串格式化新特性详解
C++怎么设置跨平台的编译环境_C++跨平台构建与CMake配置技巧
































暂无评论内容