zoukankan      html  css  js  c++  java
  • 设计模式(1)---简单工厂模式

      在面向对象系统设计中经常可以遇到以下两类问题:

    1. 为了提高内聚和松耦合,我们经常会抽象出一些类的公共接口以形成基类或接口。这样我们可以通过一个指向基类的指针来指向实际的子类实现,达到了多态的目的。这里很容易出现的一个问题就是一个太多子类继承于基类,我们不得不在每次要用到子类的地方就编写诸如 new ×××类似的代码。这里带来两个问题:A.客户程序员必须知道实际子类的名称;B.程序的扩展性和维护变得越来越困难
    2. 还有一种情况就是在父类中并不知道具体要实例化哪一个具体的子类。这里的意思为:假设类A要使用到类B,B是一个抽象父类,在A中并不知道具体要实例化哪一个B的子类,但是在类A的子类D中是可以知道的。在A中我们没有办法直接使用类似于 new ×××,因为根本就不知道 ×××是什么。

      以上两个问题也就引出了Factory模式的两个最重要功能:

    1. 定义创建对象的接口,封装了对象的创建
    2. 是的具体化类的工作延迟到了子类中
     1 #include <memory>
     2 #include <string>
     3 #include <iostream>
     4 
     5 using namespace std;
     6 
     7 class Operation
     8 {
     9 public:
    10     Operation(double numberA = 0, double numberB = 0) :numberA_(numberA), numberB_(numberB)
    11     {}
    12     void setNumberA(double numberA)
    13     {
    14         numberA_ = numberA;
    15     }
    16     double getNumberA(void)
    17     {
    18         return numberA_;
    19     }
    20     void setNumberB(double numberB)
    21     {
    22         numberB_ = numberB;
    23     }
    24     double getNumberB(void)
    25     {
    26         return numberB_;
    27     }
    28     virtual double getResult(void) = 0;
    29 protected:
    30     double numberA_;
    31     double numberB_;
    32 };
    33 
    34 class OperationAdd : public Operation
    35 {
    36 public:
    37     double getResult(void)
    38     {
    39         return numberA_ + numberB_;
    40     }
    41 };
    42 
    43 class OperationSub : public Operation
    44 {
    45 public:
    46     double getResult(void)
    47     {
    48         return numberA_ - numberB_;
    49     }
    50 };
    51 
    52 shared_ptr<Operation> createOperationFactory(char operate)
    53 {
    54     switch (operate)
    55     {
    56     case '+':
    57         return make_shared<OperationAdd>();
    58     case '-':
    59         return make_shared<OperationSub>();
    60     default:
    61         cout << "can not distinguish the operate:" << operate << endl;
    62         return nullptr;
    63     }
    64 }
    65 
    66 int main()
    67 {
    68     shared_ptr<Operation> operateAdd = createOperationFactory('+');
    69     if (nullptr == operateAdd)
    70     {
    71         return -1;
    72     }
    73     operateAdd->setNumberA(20.00);
    74     operateAdd->setNumberB(30.00);
    75 
    76     cout << operateAdd->getNumberA() << " + " << operateAdd->getNumberB() << " = " << operateAdd->getResult() << endl;
    77     return 0;
    78 }
    79  
  • 相关阅读:
    冲刺一(5)
    冲刺一(4)
    冲刺一(3)
    构建之法阅读笔记之二
    冲刺一(2)
    冲刺一(1)
    第9周总结
    热词顶会分析
    第8周总结
    构建之法阅读笔记之一
  • 原文地址:https://www.cnblogs.com/cauchy007/p/5205393.html
Copyright © 2011-2022 走看看