C++的设计模式:抽象工厂模式(Abstract Factory)

抽象工厂模式(Abstract Factory)是一种创建型设计模式,它提供了一种创建一系列相关或相互依赖对象的接口,而无需指定它们具体的类。抽象工厂模式通过将单个的简单工厂模式组合起来实现更复杂的选择逻辑,使得增加新的功能变得更加容易,从而提高了系统的抽象性和灵活性。

意图

抽象工厂模式的主要目的是提供一个接口,用于创建一系列相关或相互依赖的对象,而不需要指定它们具体的类。

应用场景

  • 当需要创建的对象是一系列相互关联或相互依赖的产品族时。
  • 当你想提供一个产品类库,而只想显示它们的接口而不是实现时。

实现

假设我们要创建一个跨平台的UI库,它可以生成不同风格(如Light和Dark主题)的UI控件(如按钮和复选框)。这里,我们可以使用抽象工厂模式来实现。

首先,我们定义UI控件的接口和具体实现。

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

// Button 接口
class Button {
public:
    virtual void paint() = 0;
    virtual ~Button() {}
};

// 具体产品:LightButton
class LightButton : public Button {
public:
    void paint() override {
        std::cout << "Rendering a button in light style." << std::endl;
    }
};

// 具体产品:DarkButton
class DarkButton : public Button {
public:
    void paint() override {
        std::cout << "Rendering a button in dark style." << std::endl;
    }
};

// CheckBox 接口
class CheckBox {
public:
    virtual void paint() = 0;
    virtual ~CheckBox() {}
};

// 具体产品:LightCheckBox
class LightCheckBox : public CheckBox {
public:
    void paint() override {
        std::cout << "Rendering a checkbox in light style." << std::endl;
    }
};

// 具体产品:DarkCheckBox
class DarkCheckBox : public CheckBox {
public:
    void paint() override {
        std::cout << "Rendering a checkbox in dark style." << std::endl;
    }
};

接着,我们定义抽象工厂接口和具体工厂。

复制代码
// GUIFactory 是抽象工厂的接口
class GUIFactory {
public:
    virtual Button* createButton() = 0;
    virtual CheckBox* createCheckBox() = 0;
    virtual ~GUIFactory() {}
};

// 具体工厂:LightFactory
class LightFactory : public GUIFactory {
public:
    Button* createButton() override {
        return new LightButton();
    }
    CheckBox* createCheckBox() override {
        return new LightCheckBox();
    }
};

// 具体工厂:DarkFactory
class DarkFactory : public GUIFactory {
public:
    Button* createButton() override {
        return new DarkButton();
    }
    CheckBox* createCheckBox() override {
        return new DarkCheckBox();
    }
};

最后,客户端代码可以这样使用:

复制代码
int main() {
    GUIFactory* factory = new LightFactory();
    Button* button = factory->createButton();
    button->paint(); // Render a button in light style.

    CheckBox* checkBox = factory->createCheckBox();
    checkBox->paint(); // Render a checkbox in light style.

    delete factory;
    delete button;
    delete checkBox;

    // 切换到暗黑风格
    factory = new DarkFactory();
    button = factory->createButton();
    button->paint(); // Render a button in dark style.

    checkBox = factory->createCheckBox();
    checkBox->paint(); // Render a checkbox in dark style.

    delete factory;
    delete button;
    delete checkBox;

    return 0;
}

总结

抽象工厂模式通过定义一个负责创建一系列相关或相互依赖对象的接口,使得创建过程被封装在工厂的内部。这样,客户端代码只需要和接口打交道,而不需要关心具体的产品类,从而使得系统更加灵活,更容易应对变化。同时,它也有助于保持产品族的一致性。

相关推荐
lingran__7 分钟前
速通ACM省铜第二天 赋源码(Adjacent XOR和Arboris Contractio)
c++·算法
zzzsde13 分钟前
【c++】类和对象(4)
开发语言·c++
抓饼先生1 小时前
C++ 20 视图view笔记
linux·开发语言·c++·笔记·c++20
大可门耳1 小时前
qt调用cef的Demo,实现js与C++之间的交互细节
javascript·c++·经验分享·qt
烛阴1 小时前
【TS 设计模式完全指南】TypeScript 装饰器模式的优雅之道
javascript·设计模式·typescript
半桔1 小时前
【STL源码剖析】二叉世界的平衡:从BST 到 AVL-tree 和 RB-tree 的插入逻辑
java·数据结构·c++·算法·set·map
R_.L1 小时前
【项目】 :C++ - 仿mudou库one thread one loop式并发服务器实现(代码实现)
服务器·开发语言·c++
R_.L1 小时前
【项目】 :C++ - 仿mudou库one thread one loop式并发服务器实现(模块划分)
服务器·c++
E___V___E2 小时前
设计模式--装饰器模式
python·设计模式·装饰器模式
孤廖2 小时前
【算法磨剑:用 C++ 思考的艺术・Dijkstra 实战】弱化版 vs 标准版模板,洛谷 P3371/P4779 双题精讲
java·开发语言·c++·程序人生·算法·贪心算法·启发式算法