设计模式-抽象工厂模式(C++)

抽象工厂模式是一种设计模式,它提供了一个接口来创建一系列相关或相互依赖的对象,而无需指定它们具体的类。下面是一个使用 C++ 实现抽象工厂模式的示例:

cpp 复制代码
// 抽象产品类
class AbstractProductA {
public:
    virtual void DoSomething() = 0;
};

class AbstractProductB {
public:
    virtual void DoSomething() = 0;
};

// 抽象工厂类
class AbstractFactory {
public:
    virtual AbstractProductA* CreateProductA() = 0;
    virtual AbstractProductB* CreateProductB() = 0;
};

// 具体产品 A1 类
class ConcreteProductA1 : public AbstractProductA {
public:
    void DoSomething() override {
        std::cout << "ConcreteProductA1::DoSomething()" << std::endl;
    }
};

// 具体产品 A2 类
class ConcreteProductA2 : public AbstractProductA {
public:
    void DoSomething() override {
        std::cout << "ConcreteProductA2::DoSomething()" << std::endl;
    }
};

// 具体产品 B1 类
class ConcreteProductB1 : public AbstractProductB {
public:
    void DoSomething() override {
        std::cout << "ConcreteProductB1::DoSomething()" << std::endl;
    }
};

// 具体产品 B2 类
class ConcreteProductB2 : public AbstractProductB {
public:
    void DoSomething() override {
        std::cout << "ConcreteProductB2::DoSomething()" << std::endl;
    }
};

// 具体工厂类
class ConcreteFactory1 : public AbstractFactory {
public:
    AbstractProductA* CreateProductA() override {
        return new ConcreteProductA1();
    }

    AbstractProductB* CreateProductB() override {
        return new ConcreteProductB1();
    }
};

class ConcreteFactory2 : public AbstractFactory {
public:
    AbstractProductA* CreateProductA() override {
        return new ConcreteProductA2();
    }

    AbstractProductB* CreateProductB() override {
        return new ConcreteProductB2();
    }
};

int main() {
    // 创建具体工厂对象
    AbstractFactory* factory1 = new ConcreteFactory1();
    AbstractFactory* factory2 = new ConcreteFactory2();

    // 通过工厂创建产品
    AbstractProductA* productA1 = factory1->CreateProductA();
    AbstractProductA* productA2 = factory2->CreateProductA();
    AbstractProductB* productB1 = factory1->CreateProductB();
    AbstractProductB* productB2 = factory2->CreateProductB();

    // 使用产品
    productA1->DoSomething();
    productA2->DoSomething();
    productB1->DoSomething();
    productB2->DoSomething();

    // 释放资源
    delete productA1;
    delete productA2;
    delete productB1;
    delete productB2;
    delete factory1;
    delete factory2;

    return 0;
}

在上述示例中,我们定义了抽象产品 AbstractProductAAbstractProductB,以及抽象工厂 AbstractFactory。具体的产品类 ConcreteProductA1ConcreteProductA2ConcreteProductB1ConcreteProductB2 继承自抽象产品类,并实现了具体的功能。具体的工厂类 ConcreteFactory1ConcreteFactory2 继承自抽象工厂类,并用于创建相应的具体产品。

main 函数中,我们创建了两个具体工厂对象 factory1factory2,然后通过它们创建了具体的产品对象 productA1productA2productB1productB2。最后,我们使用这些产品对象执行相应的操作。

通过抽象工厂模式,我们将产品的创建和使用分离,使得系统更加灵活和可扩展。当需要添加新的产品或工厂时,只需要添加相应的具体类并在工厂中进行实现,而不需要修改现有代码的其他部分。

相关推荐
静水流深_沧海一粟7 小时前
04 | 别再写几十个参数的构造函数了——建造者模式
设计模式
StarkCoder7 小时前
从UIKit到SwiftUI的迁移感悟:数据驱动的革命
设计模式
阿星AI工作室14 小时前
给openclaw龙虾造了间像素办公室!实时看它写代码、摸鱼、修bug、写日报,太可爱了吧!
前端·人工智能·设计模式
_哆啦A梦1 天前
Vibe Coding 全栈专业名词清单|设计模式·基础篇(创建型+结构型核心名词)
前端·设计模式·vibecoding
阿闽ooo5 天前
中介者模式打造多人聊天室系统
c++·设计模式·中介者模式
小米4965 天前
js设计模式 --- 工厂模式
设计模式
逆境不可逃5 天前
【从零入门23种设计模式08】结构型之组合模式(含电商业务场景)
线性代数·算法·设计模式·职场和发展·矩阵·组合模式
驴儿响叮当20105 天前
设计模式之状态模式
设计模式·状态模式
电子科技圈5 天前
XMOS推动智能音频等媒体处理技术从嵌入式系统转向全新边缘计算
人工智能·mcu·物联网·设计模式·音视频·边缘计算·iot
徐先生 @_@|||5 天前
安装依赖三方exe/msi的软件设计模式
设计模式