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

效果:

  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. 玩转python 各种数据类型的转换

    # -*- coding: utf-8 -*- # @Time : 2019/4/28 14:27 # @Author : wujf # @Email : 1028540310@qq.com # @F ...

  2. Python 切片 day3

    你可以处理列表的部分元素——Python称之为切片 . 一.使用方法: 要创建切片,可指定要使用的第一个元素和最后一个元素的索引. 与函数range() 一样,Python在到达你指定的第二个索引前面 ...

  3. eoLinker AMS 专业版V3.3发布:分享项目可以测试并选择分享内容等

    eoLinker AMS是集API文档管理.API自动化测试.开发协作三位一体的综合API开发管理平台,是中国最大的在线API管理平台.目前eoLinker AMS已经为来自全球的超过两万家企业托管超 ...

  4. 类型转换、分支(day05)

    如果表达式里包含多个不同类型的数字就必须 首先把它们转换成同一个类型然后才能 计算 这个转换过程叫做隐式类型转换,完全由 计算机完成 隐式类型转换过程中一定把占地小的类型转换 成占地大的类型 如果不同 ...

  5. AM335X开发板+4G模块 调试小结

    1.找到开发版配套资料中的linux内核源码包linux-3.2.0-Litev2.3-nand-2017-3-24.tar.gz 2.解压内核源码包,打开内核源码文件 option.c(路径为 dr ...

  6. TotoiseSVN使用教程

    TortoiseSVN百科 TortoiseSVN 是 Subversion 版本控制系统的一个免费开源客户端,可以超越时间的管理文件和目录.文件保存在中央版本库,除了能记住文件和目录的每次修改以外, ...

  7. 洛谷 P3183 BZOJ 4562 [HAOI2016]食物链

    题目描述 如图所示为某生态系统的食物网示意图,据图回答第1小题现在给你n个物种和m条能量流动关系,求其中的食物链条数.物种的名称为从1到n编号M条能量流动关系形如a1 b1a2 b2a3 b3.... ...

  8. 小记——Grub Rescue恢复

    下面我要讲的是一个悲伤的故事 引子 电脑状况简介:两块硬盘(1HHD.1SSD),SSD上装了LINUX(40G)+WIN10(50G)的双系统,SSD剩余部分在WIN下使用装程序,HHD做仓库.LI ...

  9. ExpressionTreeVisualizer

    看表达式的工具,这个工具后来微软不更新了,只支持到VS2013 表达式树的语法难度太大,语法和实现难度都大 相关文章 github地址

  10. H - Can you answer these queries? ( POJ - 3264 )

    H - Can you answer these queries? HDU - 4027   思路: 一眼思路:线段树区间修改,区间查询. 发现bug:区间的sqrt无法实现,所以还是相当于对区间的每 ...