首页 > 其他分享 >工厂模式 - 工厂方法模式、抽象工厂模式

工厂模式 - 工厂方法模式、抽象工厂模式

时间:2025-01-22 22:58:12浏览次数:3  
标签:use 创建 模式 工厂 抽象 delete

引言

工厂模式(Factory Pattern)是设计模式中创建型模式的一种,它提供了一种创建对象的最佳方式。工厂模式的核心思想是将对象的创建与使用分离,使得代码更加灵活、可扩展。工厂模式主要分为两种:工厂方法模式抽象工厂模式

本文将详细介绍工厂方法模式和抽象工厂模式的概念、实现方式以及在C++中的应用。

工厂方法模式

概念

工厂方法模式(Factory Method Pattern)定义了一个创建对象的接口,但由子类决定要实例化的类是哪一个。工厂方法模式让类的实例化推迟到子类。

优点

  1. 解耦:将对象的创建与使用分离,降低代码的耦合度。
  2. 扩展性好:新增产品类时,只需增加相应的工厂类,无需修改现有代码。
  3. 符合开闭原则:对扩展开放,对修改关闭。

缺点

  1. 类的数量增加:每增加一个产品类,就需要增加一个对应的工厂类,导致类的数量增加。
  2. 复杂性增加:对于简单的对象创建,使用工厂方法模式可能会增加代码的复杂性。

实现

下面是一个简单的工厂方法模式的实现示例:

#include <iostream>
#include <string>

// 产品接口
class Product {
public:
    virtual ~Product() {}
    virtual void use() = 0;
};

// 具体产品A
class ProductA : public Product {
public:
    void use() override {
        std::cout << "Using Product A" << std::endl;
    }
};

// 具体产品B
class ProductB : public Product {
public:
    void use() override {
        std::cout << "Using Product B" << std::endl;
    }
};

// 工厂接口
class Factory {
public:
    virtual ~Factory() {}
    virtual Product* createProduct() = 0;
};

// 具体工厂A
class FactoryA : public Factory {
public:
    Product* createProduct() override {
        return new ProductA();
    }
};

// 具体工厂B
class FactoryB : public Factory {
public:
    Product* createProduct() override {
        return new ProductB();
    }
};

int main() {
    Factory* factoryA = new FactoryA();
    Product* productA = factoryA->createProduct();
    productA->use();

    Factory* factoryB = new FactoryB();
    Product* productB = factoryB->createProduct();
    productB->use();

    delete productA;
    delete productB;
    delete factoryA;
    delete factoryB;

    return 0;
}

应用场景

工厂方法模式适用于以下场景:

  1. 不确定对象的类型:当创建对象时,不确定具体要创建哪种类型的对象。
  2. 需要扩展:当需要扩展系统,增加新的产品类时,使用工厂方法模式可以避免修改现有代码。

抽象工厂模式

概念

抽象工厂模式(Abstract Factory Pattern)提供一个创建一系列相关或相互依赖对象的接口,而无需指定它们具体的类。抽象工厂模式是工厂方法模式的扩展,它用于创建一组相关的对象。

优点

  1. 高内聚:将相关的产品族集中在一起创建,保证产品族的一致性。
  2. 解耦:将产品的创建与使用分离,降低代码的耦合度。
  3. 符合开闭原则:对扩展开放,对修改关闭。

缺点

  1. 类的数量增加:每增加一个产品族,就需要增加一个对应的工厂类,导致类的数量增加。
  2. 复杂性增加:对于简单的对象创建,使用抽象工厂模式可能会增加代码的复杂性。

实现

下面是一个简单的抽象工厂模式的实现示例:

#include <iostream>
#include <string>

// 抽象产品A
class AbstractProductA {
public:
    virtual ~AbstractProductA() {}
    virtual void use() = 0;
};

// 具体产品A1
class ProductA1 : public AbstractProductA {
public:
    void use() override {
        std::cout << "Using Product A1" << std::endl;
    }
};

// 具体产品A2
class ProductA2 : public AbstractProductA {
public:
    void use() override {
        std::cout << "Using Product A2" << std::endl;
    }
};

// 抽象产品B
class AbstractProductB {
public:
    virtual ~AbstractProductB() {}
    virtual void use() = 0;
};

// 具体产品B1
class ProductB1 : public AbstractProductB {
public:
    void use() override {
        std::cout << "Using Product B1" << std::endl;
    }
};

// 具体产品B2
class ProductB2 : public AbstractProductB {
public:
    void use() override {
        std::cout << "Using Product B2" << std::endl;
    }
};

// 抽象工厂
class AbstractFactory {
public:
    virtual ~AbstractFactory() {}
    virtual AbstractProductA* createProductA() = 0;
    virtual AbstractProductB* createProductB() = 0;
};

// 具体工厂1
class ConcreteFactory1 : public AbstractFactory {
public:
    AbstractProductA* createProductA() override {
        return new ProductA1();
    }

    AbstractProductB* createProductB() override {
        return new ProductB1();
    }
};

// 具体工厂2
class ConcreteFactory2 : public AbstractFactory {
public:
    AbstractProductA* createProductA() override {
        return new ProductA2();
    }

    AbstractProductB* createProductB() override {
        return new ProductB2();
    }
};

int main() {
    AbstractFactory* factory1 = new ConcreteFactory1();
    AbstractProductA* productA1 = factory1->createProductA();
    AbstractProductB* productB1 = factory1->createProductB();
    productA1->use();
    productB1->use();

    AbstractFactory* factory2 = new ConcreteFactory2();
    AbstractProductA* productA2 = factory2->createProductA();
    AbstractProductB* productB2 = factory2->createProductB();
    productA2->use();
    productB2->use();

    delete productA1;
    delete productB1;
    delete factory1;
    delete productA2;
    delete productB2;
    delete factory2;

    return 0;
}

应用场景

抽象工厂模式适用于以下场景:

  1. 产品族:当需要创建一组相关的产品时,使用抽象工厂模式可以保证产品族的一致性。
  2. 跨平台:当需要为不同的平台创建一组相关的产品时,使用抽象工厂模式可以方便地切换平台。

总结

工厂模式是一种非常实用的设计模式,它将对象的创建与使用分离,使得代码更加灵活、可扩展。工厂方法模式适用于创建单一产品,而抽象工厂模式适用于创建一组相关的产品。在实际开发中,根据具体需求选择合适的工厂模式,可以提高代码的可维护性和可扩展性。

希望本文能帮助你更好地理解工厂方法模式和抽象工厂模式的概念、实现方式以及应用场景。如果你有任何问题或建议,欢迎在评论区留言讨论。

标签:use,创建,模式,工厂,抽象,delete
From: https://blog.csdn.net/2301_81482480/article/details/145312115

相关文章

  • 「全网最细 + 实战源码案例」设计模式——简单工厂模式
    ​核心思想简单工厂模式是一种创建者模式,它通过一个工厂类负责创建不同类型的对象,根据传入的参数决定实例化的具体类,也被称为“静态工厂方法”模式,因为工厂方法通常是静态的。结构1.工厂类:提供一个静态方法,根据不同条件创建并返回具体的产品对象。2.产品接口(抽象类)......
  • 「全网最细 + 实战源码案例」设计模式——工厂方法模式
    核心思想简单工厂模式是一种创建者模式,它通过一个工厂类负责创建不同类型的对象,根据传入的参数决定实例化的具体类,也被称为“静态工厂方法”模式,因为工厂方法通常是静态的。结构1.工厂类:提供一个静态方法,根据不同条件创建并返回具体的产品对象。2.产品接口(抽象类)定......
  • Anthropic 计划为 Claude 发布「双向」语音模式;商汤「日日新」实时音视频对话服务开放
      开发者朋友们大家好: 这里是「RTE开发者日报」,每天和大家一起看新闻、聊八卦。我们的社区编辑团队会整理分享RTE(Real-TimeEngagement)领域内「有话题的新闻」、「有态度的观点」、「有意思的数据」、「有思考的文章」、「有看点的会议」,但内容仅代表编辑......
  • 【设计模式-行为型】职责链模式
    一、什么是职责链模式    说到职责链模式,我头脑中想到的例子就是电影《人体蜈蚣》,不过有点血腥和恶心,所以想了想还是换一个例子形容比较好,在软件行业、建筑行业或工程项目,包工程或者包项目的项目承包大佬一个个都是责任链模式的高手,层层转包层层卡油,从总承包商开始,任......
  • H3C-防火墙IPSec配置案例(主模式)
    目录1.IPSec简述:2.IPSec应用场景:3.网络拓扑及说明:4.案例背景:5.网络配置:5.1基础网络配置:5.1.1总部防火墙基础配置:5.1.2分部防火墙基础配置:5.1.3互联网路由器基础配置:5.1.4总部服务器基础配置:5.1.5总部PC基础配置:5.2IPSec配置:5.2.1总部防火墙IPSec配......
  • 【设计模式-行为型】状态模式
    一、什么是状态模式    什么是状态模式呢,这里我举一个例子来说明,在自动挡汽车中,挡位的切换是根据驾驶条件(如车速、油门踏板位置、刹车状态等)自动完成的。这种自动切换挡位的过程可以很好地用状态模式来描述。状态模式(StatePattern)是一种行为型设计模式,它允许一个对......
  • 比简单工厂更好的 - 工厂方法模式(Factory Method Pattern)
    工厂方法模式(FactoryMethodPattern)工厂方法模式(FactoryMethodPattern)工厂方法模式(FactoryMethodPattern)概述工厂方法模式(FactoryMethodPattern)结构图工厂方法模式(FactoryMethodPattern)涉及的角色talkischeap,showyoumycode总结工厂方法模式(FactoryM......
  • 9、智能驾驶域控的工作模式与启动
    针对域控制器硬件工作模式与启动需支撑L2+功能实现的要求,以下是对相关要求的概述:一、域控制器硬件工作模式要求域控制器硬件需支持下电模式、待机模式、激活模式、最小风险策略模式等,以满足自动驾驶系统在不同场景下的需求。下电模式:当车辆处于完全关闭状态时,域控制器硬件应......
  • 「全网最细 + 实战源码案例」设计模式——六大设计原则
    目的提高软件系统的可维护性和可复用性,增加软件的可拓展性和灵活性,程序员遵循6条原则来开发程序,从而提高软件开发效率、节约软件开发成本和维护成本。开闭原则(OCP)核心思想1.对拓展开放软件模块应该在不修改原有代码的情况下,通过扩展的方式增加新功能。目标:提高系统的可......
  • 「全网最细 + 实战源码案例」设计模式——单例设计模式
    核心思想:属于创建型设计模式,核心目的是确保一个类在整个程序运行期间只有一个实例,并提供一个全局访问点来获取该实例。控制共享资源的访问(如数据库链接、配置管理、日志处理器等)真实世界类比:政府是单例模式的一个很好的示例。一个国家只有一个官方政府。不管组成政府的每个......