模式意图:提供一个创建一系列相关或相互依赖对象的接口,二无需指定他们具体的类。

效果:

  1. 分离了具体的类。     使  a.客户与类的实现分离  b.客户通过抽象接口操纵实例  c.产品的类名在实现中被分离
  2. 它使得易于交换产品系列。     我们仅需转换到相应的工厂对象并从新创建接口,就能交换产品系列
  3. 有利于产品的一致性。  一个接口只能产生同一系列的对象
  4. 难以支持新种类的产品  因为接口确定了被创建的产品集合

代码实例:

头文件AbsDesk.h中定义了一个基类AbsDesk,和继承于它的两个类WoodDesk(代表过去用的桌) ,CreativeDesk (代表现在用的桌)

#ifndef _ABSDESK_
#define _ABSDESK_

#include <string>
using std::string;

class AbsDesk{
public:
AbsDesk(string name, double price):_mName(name), _mPrice(price){}
virtual void SetPrice(double price){_mPrice = price;}
virtual double GetPrice(){return _mPrice;}
string _mName;
private:
double _mPrice;
};

class WoodDesk : public AbsDesk{
public:
WoodDesk(double price, string shape)\
:AbsDesk("WoodDesk", price), _mShape(shape){}

string _mShape;
};

class CreativeDesk : public AbsDesk{
public:
CreativeDesk(double price, string shape)\
:AbsDesk("CreativeDesk", price), _mShape(shape){}

string _mShape;
};

#endif

在头文件AbsBed.h中定义了基类AbsBed,和继承于它的WoodBed 、Simmons (分别代表过去和现代用的床)

#ifndef _ABSBED_
#define _ABSBED_

#include <string>
using std::string;

class AbsBed{
public:
AbsBed(string name, double price):_mName(name), _mPrice(price){}
virtual void SetPrice(double price){_mPrice = price;}
virtual double GetPrice(){return _mPrice;}
string _mName;
private:
double _mPrice;
};

class WoodBed : public AbsBed{
public:
WoodBed(double price, double len, double wid)\
:AbsBed("WoodBed", price), _mLength(len), _mWidth(wid){}

double _mLength;
double _mWidth;
};

class Simmons : public AbsBed{
public:
Simmons(double price, double len, double wid)\
:AbsBed("Simmons", price), _mLength(len), _mWidth(wid){}

double _mLength;
double _mWidth;
};

#endif

在头文件AbsFactory中定义了基类AbsFactory,和BeforeFactory ,NowFactory (分别产生过去和现代用品)

#ifndef _FACTORY_
#define _FACTORY_
#include "AbsBed.h"
#include "AbsDesk.h"

class AbsFactory{
public:
AbsFactory(){}
virtual AbsDesk* MakeDesk(double price, string shape) const = 0;
virtual AbsBed* MakeBed(double price, double len, double wid) const = 0;
};

class BeforeFactory : public AbsFactory{
public:
BeforeFactory(){}
virtual AbsDesk* MakeDesk(double price, string shape) const\
{return new WoodDesk(price, shape);}

virtual AbsBed* MakeBed(double price, double len, double wid) const\
{return new WoodBed(price, len, wid);}
};

class NowFactory : public AbsFactory{
public:
NowFactory(){}
virtual AbsDesk* MakeDesk(double price, string shape) const\
{return new CreativeDesk(price, shape);}

virtual AbsBed* MakeBed(double price, double len, double wid) const\
{return new Simmons(price, len, wid);}
};

#endif

在main文件中:

#include <iostream>
#include <string>
using namespace std;

#include "AbsFactory.h"

int main()
{

/////////////////////////////////////////////////////////////////////////用抽象工厂产生了过去用品
AbsFactory* pFactory = new BeforeFactory;

//效果1.这里客户调用函数实现类,分离了类的实现。因为调用的事函数,客户并不是的具体的类名。

AbsBed* pBed = pFactory->MakeBed(100, 200, 180);
AbsDesk* pDesk = pFactory->MakeDesk(100, "circle");

//效果1.客户通过抽象接口操纵实例
cout<<pBed->_mName<<endl;     //输出:WoodBed
cout<<pDesk->_mName<<endl;    //输出: WoodDesk

/////////////////////////////////////////////////////////////////////////

//在不修改原代码的情况下添加了现代的Simmons和CreativeDesk //

//使抽象工厂生产了现代系列产品,体现了效果2.易于交换系列产品 //

/////////////////////////////////////////////////////////////////////////用抽象工厂产生了现代用品

pFactory = new NowFactory;

pBed = pFactory->MakeBed(100, 200, 180);
pDesk = pFactory->MakeDesk(100, "circle");
cout<<pBed->_mName<<endl;     //输出: Simmons
cout<<pDesk->_mName<<endl;    //输出: CreativeDesk

//////////////////////////////////////////////////////////////////////////

//但是因为工厂接口已经确定了产品,在不改变接口代码的情况下难以//

//在产生其它用品,如:凳子。这体现了效果4            //

//效果3:一个应用只能使用同一个系列中的对象,所以有利于产品的//

//一致性                           //

//////////////////////////////////////////////////////////////////////////

return 0;
}

结束!

抽象工厂模式(AbsFactory)C++实现的更多相关文章

  1. 设计模式(四)——Java抽象工厂模式

    抽象工厂模式 1 基本介绍 1) 抽象工厂模式:定义了一个 interface 用于创建相关或有依赖关系的对象簇,而无需指明具体的类 2) 抽象工厂模式可以将简单工厂模式和工厂方法模式进行整合. 3) ...

  2. PHP设计模式(三)抽象工厂模式(Abstract Factory For PHP)

    一.什么是抽象工厂模式 抽象工厂模式的用意为:给客户端提供一个接口,可以创建多个产品族中的产品对象 ,而且使用抽象工厂模式还要满足以下条件: 系统中有多个产品族,而系统一次只可能消费其中一族产品. 同 ...

  3. 面向对象设计模式纵横谈:Abstract Factory 抽象工厂模式(笔记记录)

         今天是设计模式的第二讲,抽象工厂的设计模式,我们还是延续老办法,一步一步的.演变的来讲,先来看看一个对象创建的问题. 1.如何创建一个对象 常规的对象创建方法: 这样的创建对象没有任何问题, ...

  4. Objective-C 工厂模式(下) -- 抽象工厂模式

    相比简单工厂模式, 只有一个工厂 能生产的手机也是固定的 抽象工厂模式类似于有很多家工厂, 当用户要买什么手机就创建对应的工厂去生产 比如用户要买iPhone就创建一个Apple工厂来生产手机, 要买 ...

  5. Net设计模式实例之抽象工厂模式(Abstract Factory Pattern)

    一.抽象工厂模式简介(Bref Introduction) 抽象工厂模式(Abstract Factory Pattern),提供一个创建一系列相关或者相互依赖对象的接口,而无需制定他们的具体类.优点 ...

  6. .NET设计模式(2):1.2 抽象工厂模式(Abstract Factory)

    概述 抽象工厂模式(Abstract Factory)是所有形态的工厂模式中最为抽象和最具一般性的一种形态.抽象工厂模式是指当有多个抽象角色时,使用的一种工厂模式.抽象工厂模式可以向客户端提供一个接口 ...

  7. 设计模式(四)抽象工厂模式(Abstract Factory Pattern)

    一.引言 在上一专题中介绍了工厂方法模式,工厂方法模式是为了克服简单工厂模式的缺点而设计出来的,简单工厂模式的工厂类随着产品类的增加需要增加额外的代码,而工厂方法模式每个具体工厂类只完成单个实例的创建 ...

  8. php实现设计模式之 抽象工厂模式

    <?php /*抽象工厂模式:提供一个创建一系统相关或相互依赖对象的接口,而无需指定它们具体的类 * 创建型模式 */ //抽象小米工厂,能制造小米一,小米二 abstract class mi ...

  9. 设计模式(3)--抽象工厂模式(Absrtact Factory Pattern)

    定义 抽象工厂模式的实质就是提供接口来创建一系列相关或独立的对象而不指定这些对象的具体类. 理解 在软件系统中,经常面临着"一系列相互依赖的对象"的创建工作:同时由于需求的变化,往 ...

随机推荐

  1. swift 类型系统 Self self Type

    namedClass:静态类型:与类型实现直接关联:可以用于初始化.类型检查等. namedClass.self:@thick,脱敏(脱关)类型:动态类型:可以作为元类型的实例:可以作为类型参量进行传 ...

  2. Apex语言(六)数组

    1.数组 数组能保存多个数据,每一个数据称为数组元素,元素的个数称为数组的长度. 数组元素的类型必须相同,元素的类型就是数组的类型. 数组元素在数组中都有一个编号,称为数组下标.下标从0开始编号,通过 ...

  3. RabbitMQ出现服务启动几秒退出问题

    最近在学习rebbitmq, 1.首先安装了otp_win64_20.3, 2.erlang安装完成需要配置erlang环境变量: 这个是新建的 文档是:ERLANG_HOME D:\develop\ ...

  4. atcoder.keyence2019.contest E-Connecting Cities

    真是道好题啊,当时怎么想都没想出来... 传送门 简述题意: 有n个点,每个点有一个权值Ai,连接i,j两个点的代价是 |i−j|×D+Ai+Aj  其中D是给定的常数,问把n个点联通的最小代价 1≤ ...

  5. jquery判断字符串中是否存在某个的字符串

    有两种方式: 1)test 2)indexOf $(function(){ var str="sunny,woo"; var sear=new RegExp(','); if(se ...

  6. 如何在 vuex action 中获取到 vue 实例

    问题:在做运营开发工具的时候 我想要请求后台服务器保存成功后 弹出一个弹框(饿了吗 的 message 弹框), 由于$message 是挂在 Vue原型链上的方法 (Vue.prototype.$m ...

  7. Problem 25

    Problem 25 The Fibonacci sequence is defined by the recurrence relation: Fn = Fn−1 + Fn−2, where F1 ...

  8. Game with a Strip

    Game with a Strip Time limit: 2.0 secondMemory limit: 64 MB There is a strip 1 × n with two sides. E ...

  9. 很实用的50个CSS代码片段

    原文:50 Useful CSS Snippets Every Designer Should Have          面对每年如此多的 新趋势 ,保持行业的率先是个非常困难问题. 站点设计者和前 ...

  10. java基础开发—jstl标签库

    在DRP项目中.接触到了JSTL标签库. 在未使用Jstl之前,我们使用JSP脚本实现一些声明或是表达式任务,做一些业务相关操作时,须要在页面中嵌入大量的java代码.在DRP项目开发前期.使用jsp ...