• C++------简单工厂模式,工厂方法模式和抽象工厂模式


    1,设计模式

      设计模式是软件开发人员在软件开发过程中面临的一般问题的解决方案。这些解决方案是众多软件开发人员经过相当长的一段时间的试验和错误总结出来的。

    2.设计模式原则

      1)开闭原则(Open Close Principle)

        开闭原则的意思是:对扩展开放,对修改关闭。在程序需要进行拓展的时候,不能去修改原有的代码。

      2里氏代换原则(Liskov Substitution Principle)

        里氏代换原则是面向对象设计的基本原则之一。 里氏代换原则中说,任何基类可以出现的地方,子类一定可以出现。LS里氏代换原则是对开闭原则的补充。实现开闭原则的关键步骤就是抽象化,而基类与子类的继承关系就是抽象化的具体实现,所以里氏代换原则是对实现抽象化的具体步骤的规范。

      3依赖倒转原则(Dependence Inversion Principle)

        这个原则是开闭原则的基础,具体内容:针对接口编程,依赖于抽象而不依赖于具体。

      4接口隔离原则(Interface Segregation Principle)

        使用多个隔离的接口,比使用单个接口要好。它还有另外一个意思是:降低类之间的耦合度。由此可见,其实设计模式就是从大型软件架构出发、便于升级和维护的软件设计思想,它强调降低依赖,降低耦合。

      5迪米特法则,又称最少知道原则(Demeter Principle)

        最少知道原则是指:一个实体应当尽量少地与其他实体之间发生相互作用,使得系统功能模块相对独立。

      6合成复用原则(Composite Reuse Principle)

        合成复用原则是指:尽量使用合成/聚合的方式,而不是使用继承。.

    3.简单工厂模式

      简单工厂模式是由一个工厂对象决定创建出哪一种产品类的实例。

      例如:

        有一家生产处理核的厂家,它只有一个工厂,能够生产两种型号的处理器核。客户需要什么样的处理器,一定要显示地告诉生产工厂。

      代码如下:

     1             #include <iostream>
     2             using namespace std;
     3             enum CTYPE {COREA,COREB};
     4             class SingleCore
     5             {
     6             public:
     7                     virtual void Show() = 0;
     8             };
     9 
    10             class SingleCoreA:public SingleCore
    11             {
    12 
    13             public:
    14                 void Show()
    15                 {
    16                     cout << "Single Core A" << endl;
    17                 }
    18             };
    19             class SingleCoreB:public SingleCore
    20             {
    21             public:
    22                 void Show()
    23                 {
    24                     cout << "Single Core B" << endl;
    25                 }
    26             };
    27             class Factory
    28 
    29             {
    30             public:
    31                 SingleCore* CreateSingleCore(enum CTYPE c)
    32                 {
    33                     if(c == COREA)
    34                     {
    35                         cout << "Create Single Core A" << endl;
    36                         return new SingleCoreA;
    37                     }
    38                     else if(c == COREB)
    39                     {
    40                         cout << "Create Single Core B" << endl;
    41                         return new SingleCoreB;
    42                     }
    43                     else
    44                     
    45                         cout << "Don't have this Core" << endl;
    46                         return NULL;
    47                     }
    48                 }
    49             };
    50 
    51             int main()
    52             {
    53                     Factory m;
    54                     SingleCore* p = m.CreateSingleCore(COREA);
    55                     p->Show();
    56                     p = m.CreateSingleCore(COREB);
    57                     p->Show();
    58             }     

      缺点:

        就是当需要增加新的处理器核类型式,需要修改工厂类,违反了开放封闭原则:可扩展,但不可修改。

    4.工厂方法模式:

      是指定义一个用于创建对象的接口,让子类决定实例化哪个类。将创建过程延迟到子类进行。

      例如:

      生产处理器的厂家,决定再开设一个工厂专门用来生产B型号的单核,一个工厂用来生产A型号的单核。这时客户要A型号的核,就找A工厂要;B型号的,找B工厂要;

      代码如下:

     1             #include <iostream>
     2             using namespace std;
     3             class SingleCore
     4             {
     5             public:
     6                 virtual void Show() = 0;
     7             };
     8             class SingleCoreA:public SingleCore
     9             {
    10             public:
    11                 void Show()
    12                 {
    13                     cout << "Single Core A" << endl;
    14                 }
    15             };
    16             class SingleCoreB:public SingleCore
    17             {
    18             public:
    19                 void Show()
    20                 {
    21                     cout << "Single Core B" << endl;
    22                 }
    23             };
    24             class Factory
    25             {
    26             public:
    27                 virtual SingleCore* CreateSingleCore() = 0;
    28             };
    29             class FactoryA:public Factory
    30             {
    31             public:
    32                 SingleCore* CreateSingleCore()
    33                 {
    34                     cout << "Create SingleCore A" << endl;
    35                     return new SingleCoreA();
    36                 }
    37             };
    38             class FactoryB:public Factory
    39             {
    40             public:
    41                 SingleCore* CreateSingleCore()
    42                 {
    43                     cout << "Create SingleCore B" << endl;
    44                     return new SingleCoreB();
    45                 }
    46             };
    47             int main()
    48             {
    49                 FactoryA m;
    50                 SingleCore* p = m.CreateSingleCore();
    51                 p->Show();
    52                 FactoryB n;
    53                 p = n.CreateSingleCore();
    54                 p->Show();
    55             }    

      缺点:

        每增加一个新产品就需要,增加一个对象的工厂。

    5.抽象工厂模式:

      是指定义一个创建一些列相关或相互依赖的对象接口,而无需指定它们具体的类。

      例如:

        这家公司的技术不断发展,现在可以生产多核的处理器,具体方法:还是开设两个工厂分别用来生产A,B两种型号的处理器。
      代码如下:

      1             #include <iostream>
      2             using namespace std;
      3             class SingleCore
      4             {
      5             public:
      6                 virtual void Show() = 0;
      7             };
      8             class SingleCoreA:public SingleCore
      9             {
     10             public:
     11                 void Show()
     12                 {
     13                     cout << " SingleCoreA"<<endl;
     14                 }
     15             };
     16             class SingleCoreB:public SingleCore
     17 
     18             {
     19             public:
     20                 void Show()
     21                 {
     22                     cout << " SingleCoreA"<<endl;
     23                 }
     24             };
     25             class SingleCoreB:public SingleCore
     26             {
     27             public:
     28                 void Show()
     29                 {
     30                     cout << "SingleCoreB" << endl;
     31                 }
     32             };
     33 
     34             class MultiCore
     35             {
     36             public:
     37                 virtual void Show() = 0;
     38             };
     39             class MultiCoreA:public MultiCore
     40             {
     41             public:
     42                 void Show()
     43                 {
     44                     cout << "MultiCoreA" << endl;
     45                 }
     46             };
     47             class MultiCoreB:public MultiCore
     48             {
     49             public:
     50                 void Show()
     51                 {
     52                     cout << "MultiCoreB" << endl;
     53                 }
     54             };
     55             class CoreFactory
     56             {
     57             public:
     58                 virtual SingleCore* createSingleCore() = 0;
     59                 virtual MultiCore* createMultiCore() = 0;
     60             };
     61 
     62             class CoreFactoryA:public CoreFactory
     63             {
     64             public:
     65                 SingleCore* createSingleCore()
     66                 {
     67                     cout << "create SingleCoreA" << endl;
     68                     return new SingleCoreA();
     69                 }
     70                 MultiCore* createMultiCore()
     71                 {
     72                     cout << "create MultiCoreA" << endl;
     73                     return new MultiCoreA();
     74 
     75                 }
     76             };
     77             class CoreFactoryB:public CoreFactory
     78             {
     79             public:
     80                 SingleCore* createSingleCore()
     81                 {
     82                     cout << "create SingleCoreB" << endl;
     83                     return new SingleCoreB();
     84                 }
     85                 MultiCore* createMultiCore()
     86                 {
     87                     cout << "create MultiCoreB" << endl;
     88                     return new MultiCoreB();
     89                 }
     90             };
     91 
     92             int main()
     93             {
     94                 CoreFactoryB Fcb;
     95                 SingleCore* core = Fcb.createSingleCore();
     96                 MultiCore* Mcore = Fcb.createMultiCore();
     97                 core->Show();
     98                 Mcore->Show();
     99                 CoreFactoryA Fca;
    100                 core = Fca.createSingleCore();
    101                 Mcore = Fca.createMultiCore();
    102                 core->Show();
    103                 Mcore->Show();
    104             }        
  • 相关阅读:
    JavaScript自定义事件
    用Java构建一个简单的WebSocket聊天室
    PHP实现支付宝小程序用户授权的工具类
    jq ajax超时设置
    gulp使用笔记
    vue学习—组件的定义注册
    echarts设置线条粗细
    求js数组的最大值和最小值
    js删除数组中的 "NaN"
    jq方法(end)
  • 原文地址:https://www.cnblogs.com/zhangzeze/p/9392598.html
Copyright © 2020-2023  润新知