抽象工厂(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. Servlet获取request的变量方法.

    1.String   localAddr = request.getLocalAddr();   // 获取本地IP,即服务器 IP 2.setAttribute(String name,Object ...

  2. 六个创建模式之原型模式(Prototype Pattern)

    定义: 使用原型实例指定创建对象的种类,并通过拷贝这个原型的属性创建新的对象. 结构图: Prototype:抽象原型类,声明克隆方法的接口,并是所有原型类的公共父类.在Java中,Object类为该 ...

  3. Redis-复制

    Redis 的复制 (replication) 是一种使用和配置起来非常简单的主从(master-slave)复制,允许 Redis 从服务器成为主服务器的精确副本.以下是关于 Redis 复制的一些 ...

  4. JQuery(选择器、事件、DOM操作)

    一.jQuery简介 jQuery 是一个 JavaScript 库. jQuery 极大地简化了 JavaScript 编程. jQuery 库位于一个 JavaScript 文件中,其中包含了所有 ...

  5. 玩转Docker之安装篇(二)

    按理说,安装软件最好是按照官方文档进行,但由于国内网络的局限性,使我们不得不搭梯子,但终究太麻烦.鉴于此情况,我推荐方案一,利用某公司的加速站点来安装,而且是傻瓜式的,非常方便. 方案一: 在linu ...

  6. Type.js – 帮助你更好的控制网页字体排版

    Type.js 是一款很好的网页字体排版工具.它可以让你使用新的 CSS 属性,在网页上试下更精细的排版控制.设置很简单.上传 type.js 到您的网站,并在你的 HTML 链接中引用.接下来,你就 ...

  7. Node.js Web 开发框架大全《路由篇》

    这篇文章与大家分享优秀的 Node.js 路由(Routers)模块.Node 是一个服务器端 JavaScript 解释器,它将改变服务器应该如何工作的概念.它的目标是帮助程序员构建高度可伸缩的应用 ...

  8. 客户端调用服务端webservice的端口问题

    今天有一个同事过来问:他有一个程序在A服务器上调第三方B服务器短信发送服务接口(webservice),无论是否发送成功,服务接口都会返回状态.现在客户要做每一个服务器 做入站端口管控,一切不必要的端 ...

  9. Android UX & UI 最佳实践: 设计有效的导航

    Best Practices for User Experience & UI Designing Effective Navigation 导航:帮助用户有效直观地使用你的应用. Plann ...

  10. 网络婚礼之AFNetWorking3.0

    目前使用人数最多的第三方网络库,没有之一.从开始的NSURLConnection到现在的NSURLSession,它都一直保持着与苹果的步调一致,而由它也衍生出大量的相关第三方网络功能库,不仅仅因为他 ...