C++ 创建型-简单工厂模式(Factory Method)

本文介绍了一种通过继承和多态实现的运算工厂设计模式,展示了如何创建不同运算类型(加、减、乘、除)的Operation子类,并通过OperationFactory动态创建并执行操作。这种设计符合依赖倒置原则,便于代码维护和扩展。
摘要由CSDN通过智能技术生成

一.  Operation基类

class Operation
{
private:
    double _numberA = 0.0f;
    double _numberB = 0.0f;

public:
    void SetNumberA(double A) { _numberA = A; }
    void SetNumberB(double B) { _numberB = B; }

    double GetNumberA() { return _numberA; }
    double GetNumberB() { return _numberB; }
public:
    virtual double GetResult();
};

double Operation::GetResult()
{
    double result = 0;
    return result;
}

二.  算法子类

class Operation_Add :public Operation
{
public:
    double GetResult() override
    {
        double result = 0;
        result = GetNumberA() + GetNumberB();
        return result;
    }
};
 

class Operation_Sub :public Operation
{
public:
    double GetResult() override
    {
        double result = 0;
        result = GetNumberA() - GetNumberB();
        return result;
    }
};

class Operation_Mul :public Operation
{
public:
    double GetResult() override
    {
        double result = 0;
        result = GetNumberA() * GetNumberB();
        return result;
    }
};
 

class Operation_Div :public Operation
{
public:
    double GetResult() override
    {
        double result = 0;
        double numberB = GetNumberB();
        if (numberB == 0) {
            std::cout << "除数不能为0," << std::endl;
            return result;
        }
        result = GetNumberA() / GetNumberB();
        return result;
    }
};

三. 运算工厂类

class OperationFactory
{
public:
    static Operation* createOperation(char operate)
    {
        Operation* oper = nullptr;
        switch (operate)
        {
        case '+':
            oper = new Operation_Add();
            break;
        case '-':
            oper = new Operation_Sub();
            break;
        case '*':
            oper = new Operation_Mul();
            break;
        case '/':
            oper = new Operation_Div();
            break;
        default:
            break;
        }
        return oper;
    }
}; 

四.  运算工厂类的使用 

#include <iostream>
#include <string>
#include <cstdio>
#include <cmath>
#include "OperationFactory.h"
using namespace std;

int main()
{
    string strNumberA;
    cout << "请输入数字A:";
    cin >> strNumberA;

    string strOperator;
    cout << "请输入运算符号(+、-、*、/):";
    cin >> strOperator;

    string strNumberB;
    cout << "请输入数字B:";
    cin >> strNumberB;

    Operation* oper = OperationFactory::createOperation(strOperator[0]);
    oper->SetNumberA(atof(strNumberA.c_str()));
    oper->SetNumberB(atof(strNumberB.c_str()));
    double dResult = oper->GetResult();
    cout << "结果是:" << std::to_string(dResult) << endl; 
}

*概念: 定义一个用于创建对象的接口,由子类决定实例化那个类的对象;

*优点:a. 没有了将应用程序类绑定到代码中的要求,代码只处理接口,因此可以使用任何实现了的接口的类;

            b.允许子类提供对象的扩展版本;

            c. 符合迪米特法则、依赖倒置原则、里氏替换原则。

*缺点:a. 需要Creator和相应的子类作为工厂方法的载体,如果应用模型确实需要creator和子类存在,则很好,否则需要增加一个类层次。

*适用场景:a. 当一个类不知道它所创建的产品的具体是那个子类时;

                   b. 当创建的对象的过程希望延缓到子类中进行时;

                   c. 当希望子类指定它要创建的对象。 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

WendyWJGu

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值