设计模式——抽象工厂模式(C++实现)

  1 #include <iostream>
  2 #include <string>
  3
  4 using namespace std;
  5
  6
  7 class STAbstractProductA
  8 {
  9 public:
 10         virtual void use() = 0;
 11 };
 12
 13 class STProductA1: public STAbstractProductA
 14 {
 15 public:
 16         virtual void use()
 17         {
 18                 cout<< "use ProductA1............"<< endl;
 19         }
 20 };
 21
 22 class STProductA2: public STAbstractProductA
 23 {
 24 public:
 25         virtual void use()
 26         {
 27                 cout<< "use ProductA2............"<< endl;
 28         }
 29 };
 30
 31 class STAbstractProductB
 32 {
 33 public:
 34         virtual void eat() = 0;
 35 };
 36
 37 class STProductB1: public STAbstractProductB
 38 {
 39 public:
 40         virtual void eat()
 41         {
 42                 cout<< "eat ProductB1............"<< endl;
 43         }
 44 };
 45
 46 class STProductB2: public STAbstractProductB
 47 {
 48 public:
 49         virtual void eat()
 50         {
 51                 cout<< "eat ProductB2............"<< endl;
 52         }
 53 };
 54
 55 class STAbstractFactory
 56 {
 57 public:
 58         virtual STAbstractProductA* CreateProductA() = 0;
 59         virtual STAbstractProductB* CreateProductB() = 0;
 60 };
 61
 62 class STConcreteFactoryA: public STAbstractFactory
 63 {
 64 public:
 65         virtual STAbstractProductA* CreateProductA()
 66         {
 67                 return new STProductA1;
 68         }
 69         virtual STAbstractProductB* CreateProductB()
 70         {
 71                 return new STProductB1;
 72         }
 73 };
 74
 75 class STConcreteFactoryB: public STAbstractFactory
 76 {
 77 public:
 78         virtual STAbstractProductA* CreateProductA()
 79         {
 80                 return new STProductA2;
 81         }
 82         virtual STAbstractProductB* CreateProductB()
 83         {
 84                 return new STProductB2;
 85         }
 86 };
 87
 88 int main(int argc, char* argv[])
 89 {
 90         STAbstractFactory* fc = new STConcreteFactoryA();
 91         STAbstractProductA* pa = fc->CreateProductA();
 92         STAbstractProductB* pb = fc->CreateProductB();
 93
 94         pa->use();
 95         pb->eat();
 96
 97         STAbstractFactory* fc2 = new STConcreteFactoryB();
 98         STAbstractProductA* pa2 = fc2->CreateProductA();
 99         STAbstractProductB* pb2 = fc2->CreateProductB();
100
101         pa2->use();
102         pb2->eat();
103
104         return 0;
105 }
106 ////////////////////////////////////////
107 [[email protected] ~/learn_code/design_pattern/9_abstract_factory]$ ./abstract_factory
108 use ProductA1............
109 eat ProductB1............
110 use ProductA2............
111 eat ProductB2............
时间: 2024-12-09 02:34:29

设计模式——抽象工厂模式(C++实现)的相关文章

设计模式-抽象工厂模式(C#)

设计模式--抽象工厂模式(JAVA) 在抽象工厂模式中,一个具体工厂可以生产一组相关的具体产品,这样的一组产品成为产品族,产品族中的每一个产品都属于某一个产品继承等等级结构.当系统所提供的工厂生产的具体产品并不是一个简单的对象,而是多个位于不同产品等级结构.属于不同类型的具体产品时就可以使用抽象工厂模式. 抽象工厂模式与工厂方法模式最大的区别在于,工厂方法模式针对的是一个产品等级结构,而抽象工厂模式需要面对多个产品等级结构,一个工厂等级结构可以负责多个不同产品等级结构中的产品对象的创建,当一个工

设计模式——抽象工厂模式学习

要想正确的理解设计模式,首先必须明确它是为了解决什么问题而提出来的. 抽象工厂设计模式概念: 针对抽象工厂这个设计模式,我查找了不少资料,感觉只有涉及产品级别和产品族的才是理解了抽象工厂设计模式的精髓,工厂方法模式针对的是一个产品等级结构:而抽象工厂模式针对的是多个产品等级结构.有些观点认为抽象工厂模式是为了解决客户端代码与工厂类的耦合问题,我认为这种观点的解决方案只是简单工厂模式的一个应用,而这种观点认为的抽象工厂模式是: 工厂模式+简单工厂模式=抽象工厂模式,这是不正确. 针对的问题: 针对

Java研究之学习设计模式-抽象工厂模式详解

 简介:          当每个抽象产品都有多于一个的具体子类的时候,工厂角色怎么知道实例化哪一个子类呢?比如每个抽象产[1] 品角色都有两个具体产品.抽象工厂模式提供两个具体工厂角色,分别对应于这两个具体产品角色,每一个具体工厂角色只负责某一个产品角色的实例化.每一个具体工厂类只负责创建抽象产品的某一个具体子类的实例. 每一个模式都是针对一定问题的解决方案,工厂方法模式针对的是一个产品等级结构:而抽象工厂模式针对的是多个产品等级结构.(摘自百度百科) 话语说得太抽象,程序员最好的表示方式

设计模式 - 抽象工厂模式(abstract factory pattern) 详解

抽象工厂模式(abstract factory pattern) 详解 本文地址: http://blog.csdn.net/caroline_wendy/article/details/27091671 参考工厂模式: http://blog.csdn.net/caroline_wendy/article/details/27081511 抽象工厂模式: 提供一个接口, 用于创建相关或依赖对象的家族, 而不需要明确指定具体类. 全部代码: http://download.csdn.net/de

设计模式 - 抽象工厂模式(abstract factory pattern) 具体解释

抽象工厂模式(abstract factory pattern) 详细解释 本文地址: http://blog.csdn.net/caroline_wendy/article/details/27091671 參考工厂模式: http://blog.csdn.net/caroline_wendy/article/details/27081511 抽象工厂模式: 提供一个接口, 用于创建相关或依赖对象的家族, 而不须要明白指定详细类. 所有代码: http://download.csdn.net/

Android设计模式——抽象工厂模式(Abstract Factory)

二十三种设计模式分为三大类: 创建型模式,共五种:工厂方法模式.抽象工厂模式.单例模式.建造者模式.原型模式. 结构型模式,共七种:适配器模式.装饰器模式.代理模式.外观模式.桥接模式.组合模式.享元模式. 行为型模式,共十一种:策略模式.模板方法模式.观察者模式.迭代子模式.责任链模式.命令模式.备忘录模式.状态模式.访问者模式.中介者模式.解释器模式. 1 package com.example.main; 2 3 import android.app.Activity; 4 import

php设计模式——抽象工厂模式(Abstract Factory)

二十三种设计模式分为三大类: 创建型模式,共五种:工厂方法模式.抽象工厂模式.单例模式.建造者模式.原型模式. 结构型模式,共七种:适配器模式.装饰器模式.代理模式.外观模式.桥接模式.组合模式.享元模式. 行为型模式,共十一种:策略模式.模板方法模式.观察者模式.迭代子模式.责任链模式.命令模式.备忘录模式.状态模式.访问者模式.中介者模式.解释器模式. 1 <?php 2 /* 3 * php设计模式——抽象工厂模式(Abstract Factory) 4 */ 5 6 7 /* 8 * I

5. 星际争霸之php设计模式--抽象工厂模式

题记==============================================================================本php设计模式专辑来源于博客(jymoz.com),现在已经访问不了了,这一系列文章是我找了很久才找到完整的,感谢作者jymoz的辛苦付出哦! 本文地址:http://www.cnblogs.com/davidhhuan/p/4248178.html============================================

JAVA设计模式--抽象工厂模式

抽象工厂设计模式 1.系统中有多个产品族,而系统一次只可能消费其中一族产品2.同属于同一个产品族的产品以其使用.来看看抽象工厂模式的各个角色(和工厂方法的如出一辙):抽象工厂角色: 这是工厂方法模式的核心,它与应用程序无关.是具体工厂角色必须实现的接口或者必须继承的父类.在java中它由抽象类或者接口来实现.具体工厂角色:它含有和具体业务逻辑有关的代码.由应用程序调用以创建对应的具体产品的对象.在java中它由具体的类来实现.抽象产品角色:它是具体产品继承的父类或者是实现的接口.在java中一般

Java设计模式——抽象工厂模式

抽象工厂模式(Abstract Factory Pattern)是属于创建型的设计模式,意在创造一个抽象的工厂,而后再由实例化出的具体的工厂来进行生产. 何时使用:系统的产品有多于一个的产品族,而系统只消费其中某一族的产品. 应用实例:工作了,为了参加一些聚会,肯定有两套或多套衣服吧,比如说有商务装(成套,一系列具体产品).时尚装(成套,一系列具体产品),甚至对于一个家庭来说,可能有商务女装.商务男装.时尚女装.时尚男装,这些也都是成套的,即一系列具体产品.假设一种情况(现实中是不存在的,要不然