当前位置: 首页 > article >正文

C++简单工厂模式

什么是简单工厂模式?

  1. 简单工厂模式属于创造型模式,而工厂就是负责生产和创造的,顾名思义。
  2. 建立对象的类就如一个工厂,而需要被建立的对象就是一个个产品;在工厂中加工产品,使用产品的人,不用在乎产品是如何生产出来的。从软件开发的角度来说,这样就有效的降低了模块之间的耦合。

简单工厂模式解决了什么问题?

  1. 客户不用关心工厂内部的构造手段,减小了客户使用代码的出错率。这里的客户表示的是使用你代码的人,当然你自己就是使用别人代码的人。
  2. 代码赋予结构性,减小了后期开发和维护难度。

简单工厂模式应用场景举例

  1. 一个软件系统提供了多个外观不同的按钮,它们都继承于按钮类,客户希望在使用这些按钮的时候,希望使用以下三个步骤来得到:
  • 调用工厂给出的创建方法;
  • 传入目标按钮对应的参数;
  • 返回目标按钮对象。

上述流程使客户使用该接口时非常方便。

分析如何构造简单工厂模式?

  1. 有一个可以统一对外输出产品的工厂类(Factory),并且该类提供了一个所有产品的统一构造方法,该方法要求传入目标产品对应的参数,返回的是目标产品对象;
  2. 一个抽象的产品类(Product);
  3. 多个具体的产品类(ProductA,ProductB…),继承于抽象的产品类。

简单工厂模式的类图

在这里插入图片描述

简单工厂模式的代码示例

#include<iostream>
#include<memory>

//工厂创造具体产品时输入的参数
typedef enum   
{
    A,B
}ProductType;


//抽象产品类
class Product
{
    public:
        Product(){std::cout<<"Product constructor"<<std::endl;};
        ~Product(){std::cout<<"Product destructor"<<std::endl;};
        virtual void produce()const{};

};

//具体产品A
class ProductA:public Product
{
    public:
        ProductA(){std::cout<<"ProductA constructor"<<std::endl;};
        ~ProductA(){std::cout<<"ProductA destructor"<<std::endl;};
        void produce()const 
        {
            std::cout<<"我是产品 A"<<std::endl;
        }
};

//具体产品B
class ProductB:public Product
{
    public:
        ProductB(){std::cout<<"ProductB constructor"<<std::endl;};
        ~ProductB(){std::cout<<"ProductB destructor"<<std::endl;};
        void produce()const 
        {
            std::cout<<"我是产品 B"<<std::endl;
        }
};

//工厂类
class Factory
{
    public:
        Factory(){std::cout<<"Factory constructor"<<std::endl;};
        ~Factory(){std::cout<<"Factory destructor"<<std::endl;};

        std::shared_ptr<Product> CreateProduct(ProductType type)//面向客户的方法,生产对应的产品只需要输入对应的产品类型即可返回(生成)对应的产品
        {
            switch (type)
            {
            case A:
                return std::make_shared<ProductA>();
                break;
            case B:
                return std::make_shared<ProductB>();
                break;
            default:
                return nullptr;
                break;
            }
        }
    
};

简单工厂模式的使用步骤和示例

  1. 构建工厂
  2. 构建抽象产品
  3. 了解具体产品
  4. 生产具体产品
  5. 投入使用
  • 示例
//
ProductType WeNeedProtductA(){return ProductType::A;};
ProductType WeNeedProtductB(){return ProductType::B;};

int main(int argc, char const *argv[])
{
    //使用步骤1:构建工厂
    Factory factory;

    //使用步骤2:构建抽象产品(客户具体需要什么产品还不知道)
    std::shared_ptr<Product>product;

    //使用步骤3:客户打电话询问得知需要A类产品
    ProductType product_type = WeNeedProtductA();

    //使用步骤4:已经确定需要的具体产品,开始生产
    product = factory.CreateProduct(static_cast<ProductType>(product_type));

    //使用步骤5:客户已经得到想要的产品,开始投入使用
    product->produce();

    return 0;
}

简单工厂模式的使用示例输出

Factory constructor
Product constructor
ProductA constructor
我是产品 A
ProductA destructor
Product destructor
Factory destructor

附录

示例代码仓库


http://www.kler.cn/a/381825.html

相关文章:

  • 如何在一个 Docker 容器中运行多个进程 ?
  • 科技资讯|谷歌Play应用商店有望支持 XR 头显,AR / VR设备有望得到发展
  • MATLAB下的四个模型的IMM例程(CV、CT左转、CT右转、CA四个模型),附下载链接
  • 【图论】——理论基础总结
  • (附项目源码)python开发语言,基于python Web的高校毕业论文管理系统 51,计算机毕设程序开发+文案(LW+PPT)
  • Linux云计算 |【第五阶段】CLOUD-DAY6
  • vue 3:监听器
  • Chrome与火狐哪个浏览器的性能表现更好
  • 计算机性能监控体系:Quark2.0
  • 用例设计方法之等价类划分法
  • Linux常用命令(你一定用得上!)
  • 基于Redis缓存机制实现高并发接口调试
  • 【大数据学习 | kafka】消费者的分区分配规则
  • WEB 应用防护系统的部署方式
  • 软件工程3.0和软件工程2.0的区别
  • 深度学习注意力机制类型总结pytorch实现代码
  • Socket篇(学习前言)
  • RabbitMQ自动发送消息工具(自动化测试RabbitMQ)
  • 群控系统服务端开发模式-应用开发-文件上传功能开发
  • qt QStandardItemModel详解
  • Hms?: 1渗透测试
  • 2DGameEngine(webGL)----初始化工程
  • SD-WAN技术怎样与运营商网络无缝集成
  • Apache HTTP Server中级操作指南
  • 100种算法【Python版】第47篇——堆排序
  • Pytest-Bdd-Playwright 系列教程(5):仅执行测试用例的收集阶段