浅谈C++设计模式之抽象工厂(Abstract Factory)
抽象工厂(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)的更多相关文章
- 【设计模式】——抽象工厂Abstract Factory
模式意图 提供对象的使用接口,隐藏对象的创建过程. 模式结构 AbstractFactory 提供创建对象的接口. ConcreteFactory 提供真正创建对象的实现类,用于组合并创建不同的对象, ...
- 设计模式四: 抽象工厂(Abstract Factory)
简介 抽象工厂模式是创建型模式的一种, 与工厂方法不同的是抽象工厂针对的是生产一组相关的产品, 即一个产品族. 抽象工厂使用工厂方法模式来生产单一产品, 单一产品的具体实现分别属于不同的产品族. 抽象 ...
- 抽象工厂(Abstract Factory),工厂方法(Factory Method),单例模式(Singleton Pattern)
在谈工厂之前,先阐述一个观点:那就是在实际程序设计中,为了设计灵活的多态代码,代码中尽量不使用new去实例化一个对象,那么不使用new去实例化对象,剩下可用的方法就可以选择使用工厂方法,原型复制等去实 ...
- 面向对象设计——抽象工厂(Abstract Factory)模式
定义 提供一个创建一系列相关或者相互依赖对象的接口,而无需指定它们具体的类.抽象工厂允许客户使用抽象的接口来创建一组相关的产品,而不需要知道或关心实际产出的具体产品是什么.这样一来,客户就能从具体的产 ...
- 设计模式——抽象工厂(Abstract Factory)
提供一个创建一系列相关或相互依赖对象的接口,而无需指定它们的具体类. ——DP UML类图 模式说明 抽象工厂与工厂方法在定义上最明显的区别是“创建一系列相关或相互依赖对象的接口”,由此可以看出抽象工 ...
- 5、抽象工厂 abstract factory 将关联组件组成产品 创建型模式
趁热打铁,紧跟着上一节的工厂方法模式.这一节介绍一下抽象工厂模式,以及分析俩个模式的不同 1.何为抽象模式? 抽象工厂模式(Abstract Factory Pattern)是围绕一个超级工厂创建其他 ...
- 工厂模式[3] 抽象工厂 Abstract Factory
简介 1.简单工厂,或静态工厂,产品接口 定义:专门定义一个类来负责创建其他类的实例,被创建的实例通常具有共同的父类或实现同一接口 优点:客户端可以直接消费产品,而不必关心具体产品的实现(不关心对象的 ...
- C2:抽象工厂 Abstract Factory
提供一个创建一系列相关或相互依赖对象的接口,而无需指定它们具体的类. 应用场景: 一系列相互依赖的对象有不同的具体实现.提供一种“封装机制”来避免客户程序和这种“多系列具体对象创建工作”的紧耦合 UM ...
- Java 工厂模式(一)— 抽象工厂(Abstract Factory)模式
一.抽象工厂模式介绍: 1.什么是抽象工厂模式: 抽象工厂模式是所有形态的工厂模式中最为抽象和最具有一般性的一种形态,抽象工厂模式向客户端提供一个接口,使得客户端在不知道具体产品的情类型的情况下,创建 ...
随机推荐
- Java经典实例:在正则表达式中控制大小写
默认是:区分大小写的: 传递标志参数:Pattern.CASE_INSENSITIVE,以说明匹配时忽略大小写:如果你的代码运行在不同的地区那么你应该再添加一个Pattern.UNICODE_CASE ...
- 说说IT技术团队招聘那点事
因为近来由于新项目的需要,各种招聘比较多,几乎每周都要面试几个人,顺便对以前的面试和带开发经验进行简单的总结 1.首先负责招聘的人一定得是自己团队的人,而且在招聘的时候一定要想清楚目标候选人进来的职责 ...
- singleCall单来源调用解析及实现
定义: 单来源调用指一个类的生成工作只能由特定类来执行. eg李宁牌鞋子只能由李宁专卖店生产 这个问题归结起来,也就是说在工厂模式中,指定的产品类只能通过具体的特定工厂类来生成,而不能自己new出来或 ...
- javascript脚本设置输入框只读的问题
今天在开发中准备通过javascript设置input框只读属性的时候,用document.getElementById('input').readonly='readonly';结果发现这样设置无效 ...
- 分享50款 Android 移动应用程序图标【下篇】
在这个移动程序流行的时代,持续增长的应用程序经济充满了商业机遇.任何对应用程序设计感兴趣的人,将会喜欢上这里的50个独特的 Android 应用程序图标.这些例子中的图标能够让应用程序的设计更具吸引力 ...
- 从零开始,做一个NodeJS博客(二):实现首页-加载文章列表和详情
标签: NodeJS 0 这个伪系列的第二篇,不过和之前的几篇是同一天写的.三分钟热度貌似还没过. 1 静态资源代理 上一篇,我们是通过判断请求的路径来直接返回结果的.简单粗暴,缺点明显:如果url后 ...
- The specified file or folder name is too long
You receive a "The specified file or folder name is too long" error message when you creat ...
- Android JNI 和 NDK
1.Android NDK 一.NDK产生的背景 Android平台从诞生起,就已经支持C.C++开发.众所周知,Android的SDK基于Java实现,这意味着基于Android SDK进行开发的第 ...
- swift 2.2 语法 (上)
前言: 1.此文中的语法会根据Swift的升级变动而更新. 2.如果需要请移步 -> swift2.2 语法(中).swift 2.2语法(下) Swift与OC中常见的区别 导入框架 OC: ...
- iOS中block的使用、实现底层、循环引用、存储位置
一.整体介绍 定义:C语言的匿名函数,