《大话设计模式》复习总结 -- 简单工厂模式

1 概念

工厂模式的定义:定义一个创建产品对象的工厂接口,将产品对象的实际创建工作推迟到具体子工厂类当中。这满足创建型模式中所要求的“创建与使用相分离”的特点。

按实际业务场景划分,工厂模式有 3 种不同的实现方式,分别是简单工厂模式、工厂方法模式和抽象工厂模式。

我们把被创建的对象称为“产品”,把创建产品的对象称为“工厂”。如果要创建的产品不多,只要一个工厂类就可以完成,这种模式叫“简单工厂模式”。

在简单工厂模式中创建实例的方法通常为静态(static)方法,因此简单工厂模式(Simple Factory Pattern)又叫作静态工厂方法模式(Static Factory Method Pattern)。

简单来说,简单工厂模式有一个具体的工厂类,可以生成多个不同的产品,属于创建型设计模式。简单工厂模式不在 GoF 23 种设计模式之列。

2 UML图

图1 简单工厂模式的UML图

3 C++示例代码

simple_factory.h

#include <iostream>

class Product {
public:
    virtual double GetResult(double a, double b) = 0;
};

class ProductA: public Product {
public:
    double GetResult(double a, double b) override;
};

class ProductB: public Product {
public:
    double GetResult(double a, double b) override;
};

class ProductC: public Product {
public:
    double GetResult(double a, double b) override;
};

class ProductD: public Product {
public:
    double GetResult(double a, double b) override;
};

class Factory {
public:
    static Product* GetProduct(int type); // 此处虽然不是强制用static,但是用static更合理,这不需要解释吧
};

simple_factory.cpp

#include <iostream>
#include "simple_factory.h"

using namespace std;

double ProductA::GetResult(double a, double b)
{
    return a + b;
}

double ProductB::GetResult(double a, double b)
{
    return a - b;
}

double ProductC::GetResult(double a, double b)
{
    return a * b;
}

double ProductD::GetResult(double a, double b)
{
    return a / b;
}

Product* Factory::GetProduct(int type)
{
    switch (type) {
        case 0:
            return new ProductA;
        case 1:
            return new ProductB;
        case 2:
            return new ProductC;
        case 3:
            return new ProductD;
    }
    return nullptr;
}

int main()
{
    Product *product = Factory::GetProduct(0);
    if (product == nullptr) {
        cout << "Get product failed" << endl;
        return -1;
    }

    double a = 0.1;
    double b = 0.2;
    double c = product->GetResult(a, b);

    cout << c << endl;
    return 0;
}

4 总结

简单工厂模式每增加一个产品就要增加一个具体产品类和一个对应的具体工厂类,这增加了系统的复杂度,违背了“开闭原则”。

优点和缺点

优点:

工厂类包含必要的逻辑判断,可以决定在什么时候创建哪一个产品的实例。客户端可以免除直接创建产品对象的职责,很方便的创建出相应的产品。工厂和产品的职责区分明确。

客户端无需知道所创建具体产品的类名,只需知道参数即可。

也可以引入配置文件,在不修改客户端代码的情况下更换和添加新的具体产品类。

缺点:

简单工厂模式的工厂类单一,负责所有产品的创建,职责过重,一旦异常,整个系统将受影响。且工厂类代码会非常臃肿,违背高聚合原则。

使用简单工厂模式会增加系统中类的个数(引入新的工厂类),增加系统的复杂度和理解难度

系统扩展困难,一旦增加新产品不得不修改工厂逻辑,在产品类型较多时,可能造成逻辑过于复杂

简单工厂模式使用了 static 工厂方法,造成工厂角色无法形成基于继承的等级结构。

应用场景

对于产品种类相对较少的情况,考虑使用简单工厂模式。使用简单工厂模式的客户端只需要传入工厂类的参数,不需要关心如何创建对象的逻辑,可以很方便地创建所需产品。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 简单工厂模式是属于创建型模式,又叫做静态工厂方法(Static Factory Method)模式,但不属于23种...
    Ritchie_Li阅读 1,324评论 0 5
  • 简单工厂模式是属于创建型模式,又叫做静态工厂方法(StaticFactoryMethod)模式,但不属于23种GO...
    RedMushrooms阅读 2,444评论 0 1
  • 简介:工厂模式大体分为 简单工厂,工厂方法,抽象工厂等三种模式。工厂方法模式也可以称为工厂模式。简单工厂进阶变成工...
    Gxy_8c77阅读 1,378评论 0 0
  • 简单工厂模式基本实现流程 具体产品类:将需要创建的各种不同产品对象的相关代码封装到具体产品类中 抽象产品类:将具体...
    沉麟阅读 4,181评论 0 0
  • 目的:通过工厂来产生对象。 使用场景:当需要创建很多对象,这样如果需要修改对象,我们就可以直接修改这个工厂类;或者...
    哈哈_6855阅读 2,312评论 0 0

友情链接更多精彩内容