意图:定义一个用于创建对象的接口,让子类觉定实例化哪一个类。

适用性:1.一个类不知道它必须创建的对象的时候。

    2.一个类希望由它的子类指定它所创建的对象的时候。

    3.当类将创建对象的职责委托给多个帮助子类中的某一个,并且希望将那一个帮助子类是代理者这一信息局部化的时候。

效果:   1.提供对象的扩展版本。

    2.连接平行的类层次。

今天学工厂方法模式,感觉得从几个工厂模式一起去理解,所以我整体的讲一下自己的想法。

开始,老板要求按客户意愿产生对应产品。于是有简单工厂,代码如下:

#ifndef _PRODUCT_
#define _PRODUCT_
#include <string>
using namespace std; class AbsProduct{
public:
AbsProduct(){}
virtual string GetProduct() = ;
}; class Product_A:public AbsProduct{
public:
Product_A(){}
virtual string GetProduct(){return "Product_A";}
}; class Product_B:public AbsProduct{
public:
Product_B(){}
virtual string GetProduct(){return "Product_B";}
}; class Product_C:public AbsProduct{
public:
Product_C(){}
virtual string GetProduct(){return "Product_C";}
}; #endif

产品部分代码

工厂部分代码:

#ifndef _FACTORY_
#define _FACTORY_
#include "Product.h" class Factory{
public:
Factory(){}
AbsProduct* MakeProduct(char ch)
{
switch (ch)
{
case 'A':
return new Product_A;
break;
case 'B':
return new Product_B;
break;
case 'C':
return new Product_C;
break;
default:
break;
}
}
}; #endif

实现部分:

#include <iostream>
#include <string>
using namespace std;
#include "Factory.h"
#include "Product.h" int main()
{
Factory factory;
AbsProduct* product = factory.MakeProduct('A');
cout<<product->GetProduct()<<endl; product = factory.MakeProduct('B');
cout<<product->GetProduct()<<endl; product = factory.MakeProduct('C');
cout<<product->GetProduct()<<endl;
return ;
}

有一天,老板又要求: 将新产品 Product_D 加入到生产。简单工厂模式虽然满足了按要求生产对应的产品,

但无法扩展新产品。于是实现了工厂方法模式:

首先产品部分添加Product_D :

class Product_D:public AbsProduct{
public:
Product_D(){}
virtual string GetProduct(){return "Product_D";}
};

工厂部分改为:

class AbsFactory{
public:
AbsFactory(){}
virtual AbsProduct* MakeFroduct() = ;
}; class Factory_A:public AbsFactory{
public:
Factory_A(){}
virtual AbsProduct* MakeFroduct(){return new Product_A;}
};
class Factory_B:public AbsFactory{
public:
Factory_B(){}
virtual AbsProduct* MakeFroduct(){return new Product_B;}
};
class Factory_C:public AbsFactory{
public:
Factory_C(){}
virtual AbsProduct* MakeFroduct(){return new Product_C;}
}; class Factory_D:public AbsFactory{
public:
Factory_D(){}
virtual AbsProduct* MakeFroduct(){return new Product_D;}
};

工厂方法工厂部分代码

实现部分:

#include <iostream>
#include <string>
using namespace std;
#include "Factory.h"
#include "Product.h" int main()
{
AbsFactory* factory = new Factory_A;
AbsProduct* product = factory->MakeFroduct();
cout<<product->GetProduct()<<endl; factory = new Factory_B;
product = factory->MakeFroduct();
cout<<product->GetProduct()<<endl; factory = new Factory_C;
product = factory->MakeFroduct();
cout<<product->GetProduct()<<endl; factory = new Factory_D;
product = factory->MakeFroduct();
cout<<product->GetProduct()<<endl; return ;
}

老板又要求了,“现在我们公司就主打这四个产品了,你们要定期更新这些产品。”

这样工厂方法虽然满足了按客户要求生产对应产品,而且也满足了扩展新产品的要求,

但无法满足新产品的更新换代。于是抽象工厂模式出来了......

对于我们的例子而已,假设公司的产品A1,B1,C1,D1为一起产品,A2,B2,C2,D2为二期产品。

则A1,A2,A3......为同一族产品。而A1,B1,C1,D1为同一等级产品。如果只工厂生产同一等级

产品,则是工厂方法模式。如果产生了不同等级产品则为抽象工厂模式。

工厂方法模式(Product)C++实现的更多相关文章

  1. C#设计模式系列:工厂方法模式(Factory Method)

    1. 工厂方法模式简介 1.1 定义 工厂方法模式定义一个用于创建对象的接口,让子类决定实例化哪一个类.工厂方法模式是以一个类的实例化延迟到其子类. Factory Method模式用于在不指定待创建 ...

  2. 【2016-10-17】【坚持学习】【Day8】【工厂方法模式】

    工厂方法模式又叫工厂模式,虚拟构造器模式 定义: 工厂父类负责定义创建产品对象的公共接口,而工厂子类则负责生成具体的产品对象目的是将产品类的实例化操作延迟到工厂子类中完成,即通过工厂子类来确定究竟应该 ...

  3. (二)工厂方法模式-C++实现

    工厂方法模式:定义一个用于创建对象的借口,让子类决定实例化哪一个类. Factory method使一个类的实例化延迟到子类. 当系统准备为用户提供某个类的子类的实例,又不想让用户代码和孩子类形成耦合 ...

  4. 深入浅出设计模式——工厂方法模式(Factory Method)

    介绍在简单工厂模式中,我们提到,工厂方法模式是简单工厂模式的一个延伸,它属于Gof23中设计模式的创建型设计模式.它解决的仍然是软件设计中与创建对象有关的问题.它可以更好的处理客户的需求变化. 引入我 ...

  5. IOS设计模式浅析之工厂方法模式(Factory Method)

    概述 在软件系统中,经常面临着“某个对象”的创建工作,由于需求的变化,这个对象的具体实现经常面临着剧烈的变化,但是它却拥有比较稳定的接口. 如何隔离出这个易变对象的变化,使得系统中“其它依赖该对象的对 ...

  6. C#设计模式——工厂方法模式(Factory Method Pattern)

    一.概述在软件系统中,经常面临着“某个对象”的创建工作,由于需求的变化,这个对象的具体实现经常面临着剧烈的变化,但是它却拥有比较稳定的接口.如何应对这种变化?如何提供一种封装机制来隔离出“这个易变对象 ...

  7. 六个创建模式之工厂方法模式(Factory Method Pattern)

    问题: 在使用简单工厂模式的时候,如果添加新的产品类,则必需修改工厂类,违反了开闭原则. 定义: 定义一个用于创建对象的接口,让子类决定具体实例化哪个产品类.此时工厂和产品都具有相同的继承结构,抽象产 ...

  8. 设计模式C#实现(九)——工厂方法模式和简单工厂

    工厂方法模式:定义一个用于创建对象的接口,让子类决定实例化哪一个类.Factory Method使一个类的实例化延迟到其子类. 构成: 1.Product工厂方法创建的对象的接口 2.Concrete ...

  9. 工厂方法模式(FACTORY METHOD)

    核心精神是封装类中不变的部分,提取其中个性化善变的部分为独立类,通过依赖注入以达到解耦.复用和方便后期维护拓展的目的. 工厂方法(Factory Method)模式的意义是定义一个创建产品对象的工厂接 ...

随机推荐

  1. 06--c++友元类

    =======================什么是友元类======================= 当一个类B成为了另外一个类A的“朋友”时,那么类A的私有和保护的数据成员就可以被类B访问.我们 ...

  2. promise原理及使用方法

    Promise 的含义 所谓Promise ,简单说就是一个容器,里面保存着某个未来才回结束的事件(通常是一个异步操作)的结果.从语法上说,Promise是一个对象,从它可以获取异步操作的消息. re ...

  3. centos 7.2 安装php56-xml

    linux下, 使用thinkphp的模板标签,如 eq, gt, volist defined, present , empty等 标签时, 报错: used undefined function ...

  4. App后台开发运维和架构实践学习总结(1)——App后台核心技术之用户验证方案

    对于初学者来说,对Token和Session的使用难免会限于困境,开发过程中知道有这个东西,但却不知道为什么要用他?更不知道其原理,今天我就带大家一起分析分析这东西. 一.使用Token进行身份鉴权 ...

  5. (28)SpringBoot启动时的Banner设置【从零开始学Spring Boot】

    对于使用过Spring Boot的开发者来说,程序启动的时候输出的由字符组成的Spring符号并不陌生.这个是Spring Boot为自己设计的Banner: 1.    .   ____       ...

  6. mysql优化sql语句

    mysql优化sql语句   常见误区   www.2cto.com   误区1:   count(1)和count(primary_key) 优于 count(*)   很多人为了统计记录条数,就使 ...

  7. 0208如何利用federated配置远程的数据库和本地数据相互交互

    -- 第一步修改本地数据库的配置文件,让其支持federated存储引擎,在[mysqld]配置文件下面增加federated[注意不能写成大写]-- federated -- 第二步创建一个数据库, ...

  8. [Linux]Apache配置虚拟主机

    Apache 配置虚拟主机的方式很多,种类也很多,主要分为两类:   基于名称的虚拟主机 (每个 IP 多个站点) 基于 IP 的虚拟主机 (每个 IP 一个站点) 基于名称的虚拟主机:  www.2 ...

  9. POJ 2030

    简单DP题. 可以用运算符重载来写,简单一些. #include <iostream> #include <cstdio> #include <cstring> # ...

  10. POJ 1474

    半平面交模板 #include <iostream> #include <cstdio> #include <cstring> #include <algor ...