抽象工厂(Abstract Factory)模式是为了提供一系列相关或相互依赖对象的接口。对象创建型模式的一种。

  • 客户Client
  • 抽象工厂接口AbstractFactory
  • 抽象工厂的实现类ConcreteFactory
  • 抽象产品接口AbstractProduct
  • 产品实现类ConcreteProduct

  我们要生产两个系列四种产品,分别是ConcreteProductA1/ConcreteProductA2/ConcreteProductB1/ConcreteProductB2。各个系列产品的启动和退出方式相同,但是运行方式不同。这里分别用一个具体工厂ConcreteFactory1和ConcreteFactory2的对象来生产多种产品。

1、AbstractFactory(声明一个创建抽象产品对象的接口)

class AbstractFactory{
public:
AbstractFactory(){};
~AbstractFactory(){};
virtual AbstractProductA* createProductA()=;
virtual AbstractProductB* createProductB()=;
};

2、ConcreteFactory(实现创建具体产品对象的操作)

/************************工厂1***************************/
class ConcreteFactory1:public AbstractFactory{
public:
ConcreteFactory1(){};
~ConcreteFactory1(){};
AbstractProductA* createProductA();
AbstractProductB* createProductB();
};
void ConcreteFactory1::createProductA(){
return new AbstractProductA();
}
void ConcreteFactory1::vreateProdyctB(){
return new AbstractProductB();
}
/************************工厂2***************************/
class ConcreteFactory2:public AbstractFactory{
public:
ConcreteFactory2(){};
~ConcreteFactory2(){};
AbstractProductA* createProductA();
AbstractProductB* createProductB();
};
void ConcreteFactory2::createProductA(){
return new AbstractProductA();
}
void ConcreteFactory2::vreateProdyctB(){
return new AbstractProductB();
}

3、AbstractProduct(为一类产品对象声明一个接口)

/**************************抽象产品A*****************************/
class AbstractProductA{
public:
AbstractProductA(){};
~AbstractProductA(){};
void start();
virtual void execute()=;
void quit();
};
void AbstractProductA::start(){
cout<<"<---------------------A类产品是这样启动的----------------------->"<endl;
}
void AbstractProductA::quit(){
cout<<"<---------------------A类产品是这样退出的----------------------->"<endl;
}
/**************************抽象产品B*****************************/
class AbstractProductB{
public:
AbstractProductB(){};
~AbstractProductB(){};
void start();
virtual void execute()=;
void quit();
};
void AbstractProductB::start(){
cout<<"<---------------------B类产品是这样启动的----------------------->"<endl;
}
void AbstractProductB::quit(){
cout<<"<---------------------B类产品是这样退出的----------------------->"<endl;
}

4、ConcreteProduct(定义一个将被相应的具体工厂创建的产品对象,实现AbstractProduct接口)

/**************************抽象产品A的具体产品A1*****************************/
class ConcreteProductA1:public AbstractProductA{
public:
ConcreteProductA1(){};
~ConcreteProductA1(){};
void execute();
};
void ConcreteProductA1::execute(){
cout<<"<---------------------产品1是这样运行的----------------------->"<endl;
}
/**************************抽象产品A的具体产品A2*****************************/
class ConcreteProductA2:public AbstractProductA{
public:
ConcreteProductA2(){};
~ConcreteProductA2(){};
void execute();
};
void ConcreteProductA2::execute(){
cout<<"<---------------------产品2是这样运行的----------------------->"<endl;
}
/**************************抽象产品B的具体产品B1*****************************/
class ConcreteProductB1:public AbstractProductB{
public:
ConcreteProductB1(){};
~ConcreteProductB1(){};
void execute();
};
void ConcreteProductB1::execute(){
cout<<"<---------------------产品1是这样运行的----------------------->"<endl;
}
/**************************抽象产品B的具体产品B2*****************************/
class ConcreteProductB2:public AbstractProductB{
public:
ConcreteProductB2(){};
~ConcreteProductB2(){};
void execute();
};
void ConcreteProductB2::execute(){
cout<<"<---------------------产品2是这样运行的----------------------->"<endl;
}

5、客户Client

int main(){
AbstractFactory *factory1 = new ConcreteFactory1();
/*********************生产产品A1****************************/
ConcreteProductA *pA1 = factory1.createProductA();
pA1->start(); //A是这么启动的
pA1->execute(); //A1是这样运行的
pA1->quit(); //A是这样退出的
/*********************生产产品B1****************************/
ConcreteProductB *pB1 = factory1.createProductB();
pB1->start(); //B是这么启动的
pB1->execute(); //B1是这样运行的
pB1->quit(); //B是这样退出的 AbstractFactory *factory2 = new ConcreteFactory2();
/*********************生产产品A2****************************/
ConcreteProductA *pA2 = factory2.createProductA();
pA2->start(); //A是这么启动的
pA2->execute(); //A2是这样运行的
pA2->quit(); //A是这样退出的
/*********************生产产品B2****************************/
ConcreteProductB *pB2 = factory2.createProductB();
pB2->start(); //B是这么启动的
pB2->execute(); //B2是这样运行的
pB2->quit(); //B是这样退出的 return ;
}

  抽象工厂跟工厂方法模式可能区分有点模糊:工厂方法模式针对的是一个产品等级结构;而抽象工厂模式针对的是多个产品等级结构。抽象工厂模式主要用来实现生产一系列的产品。

  版权所有,欢迎转载,转载请注明出处。

浅谈C++设计模式之抽象工厂(Abstract Factory)的更多相关文章

  1. 【设计模式】——抽象工厂Abstract Factory

    模式意图 提供对象的使用接口,隐藏对象的创建过程. 模式结构 AbstractFactory 提供创建对象的接口. ConcreteFactory 提供真正创建对象的实现类,用于组合并创建不同的对象, ...

  2. 设计模式四: 抽象工厂(Abstract Factory)

    简介 抽象工厂模式是创建型模式的一种, 与工厂方法不同的是抽象工厂针对的是生产一组相关的产品, 即一个产品族. 抽象工厂使用工厂方法模式来生产单一产品, 单一产品的具体实现分别属于不同的产品族. 抽象 ...

  3. 抽象工厂(Abstract Factory),工厂方法(Factory Method),单例模式(Singleton Pattern)

    在谈工厂之前,先阐述一个观点:那就是在实际程序设计中,为了设计灵活的多态代码,代码中尽量不使用new去实例化一个对象,那么不使用new去实例化对象,剩下可用的方法就可以选择使用工厂方法,原型复制等去实 ...

  4. 面向对象设计——抽象工厂(Abstract Factory)模式

    定义 提供一个创建一系列相关或者相互依赖对象的接口,而无需指定它们具体的类.抽象工厂允许客户使用抽象的接口来创建一组相关的产品,而不需要知道或关心实际产出的具体产品是什么.这样一来,客户就能从具体的产 ...

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

    提供一个创建一系列相关或相互依赖对象的接口,而无需指定它们的具体类. ——DP UML类图 模式说明 抽象工厂与工厂方法在定义上最明显的区别是“创建一系列相关或相互依赖对象的接口”,由此可以看出抽象工 ...

  6. 5、抽象工厂 abstract factory 将关联组件组成产品 创建型模式

    趁热打铁,紧跟着上一节的工厂方法模式.这一节介绍一下抽象工厂模式,以及分析俩个模式的不同 1.何为抽象模式? 抽象工厂模式(Abstract Factory Pattern)是围绕一个超级工厂创建其他 ...

  7. 工厂模式[3] 抽象工厂 Abstract Factory

    简介 1.简单工厂,或静态工厂,产品接口 定义:专门定义一个类来负责创建其他类的实例,被创建的实例通常具有共同的父类或实现同一接口 优点:客户端可以直接消费产品,而不必关心具体产品的实现(不关心对象的 ...

  8. C2:抽象工厂 Abstract Factory

    提供一个创建一系列相关或相互依赖对象的接口,而无需指定它们具体的类. 应用场景: 一系列相互依赖的对象有不同的具体实现.提供一种“封装机制”来避免客户程序和这种“多系列具体对象创建工作”的紧耦合 UM ...

  9. Java 工厂模式(一)— 抽象工厂(Abstract Factory)模式

    一.抽象工厂模式介绍: 1.什么是抽象工厂模式: 抽象工厂模式是所有形态的工厂模式中最为抽象和最具有一般性的一种形态,抽象工厂模式向客户端提供一个接口,使得客户端在不知道具体产品的情类型的情况下,创建 ...

随机推荐

  1. sql2000安装的一般问题

    SQLServer2000 在一段时间不使用后突然间不能够运行了.只能打开企业管理器,对数据库进行操作.VS2005不能够连接,试了很多种方式,无结果.于是重新安装 sqlServer2000? 仿真 ...

  2. SpringMVC 邮件发送

    <!--邮件发送实现类--> <bean id="javaMailSender" class="org.springframework.mail.jav ...

  3. C#语言的基础

    一.C#的引入 01..net和C#的区别 1)大概在2000年,微软推出了一种革命性的产品--.NET(战略) 目标:任何人,在任何地方,使用任何终端设备,都可以访问微软提供的服务. 2).net ...

  4. php 相关模块备忘

    在安装php的时候,不管是编译安装: ./configure --prefix=/usr/local/php --with-config-file-path=/usr/local/php/etc -- ...

  5. CSS3中DIV水平垂直居中-2(3)

    用到CSS3中display的新属性. HTML <div class="parent"> </div> CSS html,body{ width: 100 ...

  6. Asp.net Ibatis 增、删、改、查

    好久都没用.net Ibatis配置了 今天给大家分享一下获取它的增.删.改.查. #region 节点类型表 public bool InsertNodeType(NodeType allRevie ...

  7. 一个插件让你在chrome直接运行apk

    插件的下载地址: https://chrome.google.com/webstore/detail/arc-welder/emfinbmielocnlhgmfkkmkngdoccbadn?utm_s ...

  8. [android]亲自破解Flappy Bird(去广告+永生)

    以下内容为原创,欢迎转载,转载请注明 来自天天博客:http://www.cnblogs.com/tiantianbyconan/p/3544785.html  听说最近Flappy Bird很火,但 ...

  9. 发布一个java Servlet (静态发布)

    Servlet 是sun开发的动态web资源 的技术 让 Servlet 能响应用户请求,必须将 Servlet 配置在 Web 应用中 如何将Servlet用Tomcat发布出去: 编译你的.jav ...

  10. Android进程管理及静态变量垃圾回收

    1.Android静态变量的生命周期 静态变量的生命周期遵守Java的设计.我们知道静态变量是在类被load的时候分配内存的,并且存在于方法 区.当类被卸载的时候,静态变量被销毁. 在PC机的客户端程 ...