抽象工厂(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. HR人力资源战略流程制定

    HR人力资源战略 是指根据企业总体战略的要求,为适应企业生存和发展的需要,对企业人力资源进行开发,提高职工队伍的整体素质,从中发现和培养出一大批优秀人才,所进行的长远性的人力资源管理方面的专业谋划和方 ...

  2. 设计一个较好的框架的难点之一--API兼容性的设计

    设计一个好的框架和设计一个好的软件一样,需要考虑的方面很多,比如扩展性.性能.用户体验.稳健性等等,视不同的场景,每个点都可能导致成败,但他们通常并不是老板们关心的,因为在大部分情况下,他们通常都没有 ...

  3. java集合-HashMap

    HashMap基于哈希表的 Map 接口的实现,以 key-value 的形式存在.在 HashMap 中,key-value 总是会当做一个整体来处理,系统会根据 hash 算法来来计算 key-v ...

  4. ArcGIS server开发之API for js 本地部署

    ArcGIS Server for javascript 本地部署 第一次使用arcgis server for js开发,在经验方面还有很多的不足,所以将自己在开发过程中遇到的问题写出来与大家共享. ...

  5. 12款最佳的 WordPress 语法高亮插件推荐

    语法高亮工具增强了代码的可读性,美化了代码,让程序员更容易维护.语法高亮提供各种方式由以提高可读性和文本语境,尤其是对于其中可以结束跨越多个页面的代码,以及让开发者自己的程序中查找错误.在这篇文章中, ...

  6. CSS学习总结(三)

    一.属性选择符 如下表所示: 例子如下: <head> <meta charset="utf-8"> <style type="text/c ...

  7. [Java] Java record

    2-1 java中的封装 概念: 将类的某些信息隐藏在类内部,不允许外部程序直接访问,而是通过该类提供的方法类实现对隐藏信息的操作和访问. 好处: 1. 只能通过规定的方法访问数据 2. 隐藏类的实例 ...

  8. iOS界面传值的方式(7种)

    iOS传值的方式 属性传值 方法传值 代理传值(delegate) block传值 单例模式方式 通知notification方式 UserDefault或者文件方式 1.属性传值 情况:A页面跳转到 ...

  9. Java虚拟机JVM学习06 自定义类加载器 父委托机制和命名空间的再讨论

    Java虚拟机JVM学习06 自定义类加载器 父委托机制和命名空间的再讨论 创建用户自定义的类加载器 要创建用户自定义的类加载器,只需要扩展java.lang.ClassLoader类,然后覆盖它的f ...

  10. Android Animation学习(五) ApiDemos解析:容器布局动画 LayoutTransition

    Android Animation学习(五) ApiDemos解析:容器布局动画 LayoutTransition Property animation系统还提供了对ViewGroup中的View改变 ...