实例解析C++设计模式编程中简单工厂模式的采用

 更新时间:2016年03月04日 09:41:50   作者:Riddick  
这篇文章主要介绍了C++设计模式编程中简单工厂模式的采用实例,在简单工厂模式中程序往往利用封装继承来降低耦合度,需要的朋友可以参考下

简单工厂模式中专门定义一个类来负责创建其他类的实例,被创建的实例通常都具有共同的父类。它又称为静态工厂方法模式,属于类的创建型模式。
简单工厂模式的UML类图

20163494015350.jpg (361×177)

简单工厂模式的程序通过封装继承来降低程序的耦合度,设计模式使得程序更加的灵活,易修该,易于复用。

简单工厂是在工厂类中做判断,从而创造相应的产品。


简单工厂模式的实质是由一个工厂类根据传入的参数,动态决定应该创建哪一个产品类(这些产品类继承自一个父类或接口)的实例。
 
该模式中包含的角色及其职责
 
1.工厂(Creator)角色
 
简单工厂模式的核心,它负责实现创建所有实例的内部逻辑。工厂类可以被外界直接调用,创建所需的产品对象。
 
2.抽象(Product)角色
 
简单工厂模式所创建的所有对象的父类,它负责描述所有实例所共有的公共接口。
 
3.具体产品(Concrete Product)角色
 
是简单工厂模式的创建目标,所有创建的对象都是充当这个角色的某个具体类的实例。
一般来讲它是抽象产品类的子类,实现了抽象产品类中定义的所有接口方法。
 
简单工厂模式的特点:
 
简单工厂模式的创建目标,所有创建的对象都是充当这个角色的某个具体类的实例。
在这个模式中,工厂类是整个模式的关键所在。它包含必要的判断逻辑,能够根据外界给定的信息,决定究竟应该创建哪个具体类的对象。用户在使用时可以直接根据工厂类去创建所需的实例,而无需了解这些对象是如何创建以及如何组织的。有利于整个软件体系结构的优化。
不难发现,简单工厂模式的缺点也正体现在其工厂类上,由于工厂类集中了所有实例的创建逻辑,所以“高内聚”方面做的并不好。另外,当系统中的具体产品类不断增多时,可能会出现要求工厂类也要做相应的修改,扩展性并不很好。

举个例子:有一家生产处理器核的厂家,它只有一个工厂,能够生产两种型号的处理器核。客户需要什么样的处理器核,一定要显示地告诉生产工厂。
下面给出一种实现方案。

#include <iostream>
using namespace std;

enum CoreType
{
 CORE_A,
 CORE_B
};

class SingleCore
{
public:
 virtual void Show() = 0;
};

/*
 * A 型号单核
 */
class SingleCoreA: public SingleCore
{
public:
 void Show()
 {
 cout<<"show SingleCoreA"<<endl;
 }
};

/*
 * B 型号单核
 */
class SingleCoreB: public SingleCore
{
public:
 void Show()
 {
 cout<<"show SingleCoreB"<<endl;
 }
};

/*
 * 唯一的工厂,可以生产单核 两种型号的处理器
 */ 
class Factory
{
public:
 SingleCore* CreateSingleCore(CoreType ctype)
 {
 switch(ctype) 
 {
 case CORE_A:
 return new SingleCoreA();

 case CORE_B:
 return new SingleCoreB();
 
 default:
 return NULL;
 }
 }
};


int main()
{
 Factory   *pstFactory;
 SingleCore *pstSingleCore;
 
 pstFactory  = new Factory();

 /*
 * 生产A核
 */
 pstSingleCore = pstFactory->CreateSingleCore(CORE_A);
 pstSingleCore->Show();

 system("pause");

 /*
 * 生产B核
 */
 pstSingleCore = pstFactory->CreateSingleCore(CORE_B);
 pstSingleCore->Show();

 /*
 * 生产A核
 */
 pstSingleCore = pstFactory->CreateSingleCore(CORE_A);
 pstSingleCore->Show();

 /*
 * 生产A核
 */
 pstSingleCore->Show();

 system("pause");

 /*
 * 生产B核
 */
 pstSingleCore = pstFactory->CreateSingleCore(CORE_B);
 pstSingleCore->Show();
 
 return 0;
}

运行结果:

show SingleCoreA
请按任意键继续. . .
show SingleCoreB
show SingleCoreA
show SingleCoreA
请按任意键继续. . .
show SingleCoreB
Press any key to continue 

相关文章

  • 详解C++中构造函数,拷贝构造函数和赋值函数的区别和实现

    详解C++中构造函数,拷贝构造函数和赋值函数的区别和实现

    这篇文章主要介绍了C++中构造函数,拷贝构造函数和赋值函数的区别和实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-03-03
  • C++进程间共享数据实例

    C++进程间共享数据实例

    这篇文章主要介绍了C++进程间共享数据的方法,是进行C++应用程序开发中非常实用的技巧,需要的朋友可以参考下
    2014-10-10
  • 深入解析C++中的字符数组和处理字符串的方法

    深入解析C++中的字符数组和处理字符串的方法

    这篇文章主要介绍了深入解析C++中的字符数组和处理字符串的方法,需要的朋友可以参考下
    2015-09-09
  • c++容器list、vector、map、set区别与用法详解

    c++容器list、vector、map、set区别与用法详解

    这篇文章主要介绍了c++容器list、vector、map、set区别与用法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-05-05
  • C++小知识:C/C++中不要按值传递数组

    C++小知识:C/C++中不要按值传递数组

    今天小编就为大家分享一篇关于C++小知识:C/C++中不要按值传递数组,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-01-01
  • C++11中内联函数(inline)用法实例

    C++11中内联函数(inline)用法实例

    内联函数本质还是一个函数,但在声明的时候,函数体要和声明结合在一起,否则编译器将它作为普通函数来对待,下面这篇文章主要给大家介绍了关于C++11中内联函数(inline)的相关资料,需要的朋友可以参考下
    2022-10-10
  • C++中double浮点数精度丢失的深入分析

    C++中double浮点数精度丢失的深入分析

    这篇文章主要给大家介绍了关于C++中double浮点数精度丢失的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-01-01
  • C++ Qt开发之CheckBox多选框组件的用法详解

    C++ Qt开发之CheckBox多选框组件的用法详解

    Qt是一个跨平台C++图形界面开发库,利用Qt可以快速开发跨平台窗体应用程序,在Qt中我们可以通过拖拽的方式将不同组件放到指定的位置,实现图形化开发极大的方便了开发效率,本章将重点介绍CheckBox单行输入框组件的使用方法,需要的朋友可以参考下
    2023-12-12
  • C++中signed main和int main的区别

    C++中signed main和int main的区别

    这篇文章介绍了C++中signed main和int main的区别,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-12-12
  • 自己实现strcpy函数的实现方法

    自己实现strcpy函数的实现方法

    本篇文章介绍了,自己实现strcpy函数的实现方法。需要的朋友参考下
    2013-05-05

最新评论