工厂模式(转)

软件领域中的设计模式为开发人员提供了一种使用专家设计经验的有效途径。设计模式中运用了面向对象编程语言的重要特性:封装、继承、多态,真正领悟设计模式的精髓是可能一个漫长的过程,需要大量实践经验的积累。最近看设计模式的书,对于每个模式,用C++写了个小例子,加深一下理解。主要参考《大话设计模式》和《设计模式:可复用面向对象软件的基础》两本书。本文介绍工厂模式的实现。

工厂模式属于创建型模式,大致可以分为三类,简单工厂模式、工厂方法模式、抽象工厂模式。听上去差不多,都是工厂模式。下面一个个介绍,首先介绍简单工厂模式,它的主要特点是需要在工厂类中做判断,从而创造相应的产品。当增加新的产品时,就需要修改工厂类。有点抽象,举个例子就明白了。有一家生产处理器核的厂家,它只有一个工厂,能够生产两种型号的处理器核。客户需要什么样的处理器核,一定要显示地告诉生产工厂。下面给出一种实现方案。

[cpp] view plaincopyprint?

  1. enum CTYPE {COREA, COREB};
  2. class SingleCore
  3. {
  4. public:
  5. virtual void Show() = 0;
  6. };
  7. //单核A
  8. class SingleCoreA: public SingleCore
  9. {
  10. public:
  11. void Show() { cout<<"SingleCore A"<<endl; }
  12. };
  13. //单核B
  14. class SingleCoreB: public SingleCore
  15. {
  16. public:
  17. void Show() { cout<<"SingleCore B"<<endl; }
  18. };
  19. //唯一的工厂,可以生产两种型号的处理器核,在内部判断
  20. class Factory
  21. {
  22. public:
  23. SingleCore* CreateSingleCore(enum CTYPE ctype)
  24. {
  25. if(ctype == COREA) //工厂内部判断
  26. return new SingleCoreA(); //生产核A
  27. else if(ctype == COREB)
  28. return new SingleCoreB(); //生产核B
  29. else
  30. return NULL;
  31. }
  32. };

调用的时候可以   SingleCore MyCore=CreateSingleCore(0) ;

这样设计的主要缺点之前也提到过,就是要增加新的核类型时,就需要修改工厂类。这就违反了开放封闭原则:软件实体(类、模块、函数)可以扩展,但是不可修改。于是,工厂方法模式出现了。所谓工厂方法模式,是指定义一个用于创建对象的接口,让子类决定实例化哪一个类。Factory Method使一个类的实例化延迟到其子类。

听起来很抽象,还是以刚才的例子解释。这家生产处理器核的产家赚了不少钱,于是决定再开设一个工厂专门用来生产B型号的单核,而原来的工厂专门用来生产A型号的单核。这时,客户要做的是找好工厂,比如要A型号的核,就找A工厂要;否则找B工厂要,不再需要告诉工厂具体要什么型号的处理器核了。下面给出一个实现方案。

[cpp] view plaincopyprint?

  1. class SingleCore
  2. {
  3. public:
  4. virtual void Show() = 0;
  5. };
  6. //单核A
  7. class SingleCoreA: public SingleCore
  8. {
  9. public:
  10. void Show() { cout<<"SingleCore A"<<endl; }
  11. };
  12. //单核B
  13. class SingleCoreB: public SingleCore
  14. {
  15. public:
  16. void Show() { cout<<"SingleCore B"<<endl; }
  17. };
  18. class Factory
  19. {
  20. public:
  21. virtual SingleCore* CreateSingleCore() = 0;
  22. };
  23. //生产A核的工厂
  24. class FactoryA: public Factory
  25. {
  26. public:
  27. SingleCoreA* CreateSingleCore() { return new SingleCoreA; }
  28. };
  29. //生产B核的工厂
  30. class FactoryB: public Factory
  31. {
  32. public:
  33. SingleCoreB* CreateSingleCore() { return new SingleCoreB; }
  34. };

工厂方法模式也有缺点,每增加一种产品,就需要增加一个对象的工厂。如果这家公司发展迅速,推出了很多新的处理器核,那么就要开设相应的新工厂。在C++实现中,就是要定义一个个的工厂类。显然,相比简单工厂模式,工厂方法模式需要更多的类定义。

既然有了简单工厂模式和工厂方法模式,为什么还要有抽象工厂模式呢?它到底有什么作用呢?还是举这个例子,这家公司的技术不断进步,不仅可以生产单核处理器,也能生产多核处理器。现在简单工厂模式和工厂方法模式都鞭长莫及。抽象工厂模式登场了。它的定义为提供一个创建一系列相关或相互依赖对象的接口,而无需指定它们具体的类。具体这样应用,这家公司还是开设两个工厂,一个专门用来生产A型号的单核多核处理器,而另一个工厂专门用来生产B型号的单核多核处理器,下面给出实现的代码。

[cpp] view plaincopyprint?

  1. //单核
  2. class SingleCore
  3. {
  4. public:
  5. virtual void Show() = 0;
  6. };
  7. class SingleCoreA: public SingleCore
  8. {
  9. public:
  10. void Show() { cout<<"Single Core A"<<endl; }
  11. };
  12. class SingleCoreB :public SingleCore
  13. {
  14. public:
  15. void Show() { cout<<"Single Core B"<<endl; }
  16. };
  17. //多核
  18. class MultiCore
  19. {
  20. public:
  21. virtual void Show() = 0;
  22. };
  23. class MultiCoreA : public MultiCore
  24. {
  25. public:
  26. void Show() { cout<<"Multi Core A"<<endl; }
  27. };
  28. class MultiCoreB : public MultiCore
  29. {
  30. public:
  31. void Show() { cout<<"Multi Core B"<<endl; }
  32. };
  33. //工厂
  34. class CoreFactory
  35. {
  36. public:
  37. virtual SingleCore* CreateSingleCore() = 0;
  38. virtual MultiCore* CreateMultiCore() = 0;
  39. };
  40. //工厂A,专门用来生产A型号的处理器
  41. class FactoryA :public CoreFactory
  42. {
  43. public:
  44. SingleCore* CreateSingleCore() { return new SingleCoreA(); }
  45. MultiCore* CreateMultiCore() { return new MultiCoreA(); }
  46. };
  47. //工厂B,专门用来生产B型号的处理器
  48. class FactoryB : public CoreFactory
  49. {
  50. public:
  51. SingleCore* CreateSingleCore() { return new SingleCoreB(); }
  52. MultiCore* CreateMultiCore() { return new MultiCoreB(); }
  53. };

工厂模式(转)

时间: 2024-11-05 23:24:35

工厂模式(转)的相关文章

抽象工厂模式

思考:工厂方法模式:http://www.cnblogs.com/maggiejyt/p/7561253.html 工厂方法模式UML: 问题:如果这家工厂不止要生产Ball(球),还要还有Sneakers(球鞋)等 则UML图为 当Product有多种类时则是抽象工厂模式 代码(Ball的代码见简单工厂模式:http://www.cnblogs.com/maggiejyt/p/7561253.html) Sneakers(球鞋抽象类) package com.maggie.FactoryMet

设计模式 2/23 工厂模式

工厂模式是最常用的设计模式之一,用好了,代码优雅,可维护性高,对系统设计会上一个台阶 为什么这么说,因为工厂模式可以牵扯出抽象工厂模式,也有大家都会聊到的简单工厂模式 我们要了解一点,23中设计模式中,不包含简单工厂模式,之所以大家会去聊这个,四个字,渐进明细 通过对简单工厂模式的了解,我们引入工厂这个词,不然一个写代码的,天天给他讲工厂,工厂,工厂,西厂,东厂,会晕 同时,通过逐步的深入,从简单工厂,到工厂模式,再到抽象工厂,渐进明细的过程,逐步深入的理解,比较优劣,择优而为我们所用. 试想我

简单工厂模式

目前正在看<大话设计模式>,写此系列的文章记录下学习的经过. 简单工厂模式 先看如下代码,使用面向对象的原理实现计算器功能 Operation运算类 1 public class Operation 2 { 3 private double numberA = 0; 4 private double numberB = 0; 5 6 public double NumberA 7 { 8 get { return numberA; } 9 set { numberA = value; } 10

设计模式——介绍与工厂模式(扁平管理模式VS职业经理人模式)

本文主要对设计模式进行大概解说.特别是对工厂模式进行简明的解析: 一.设计模式的分类 创建型模式,共五种:工厂方法模式.抽象工厂模式.单例模式.建造者模式.原型模式. 结构型模式,共七种:适配器模式.装饰器模式.代理模式.外观模式.桥接模式.组合模式.享元模式. 行为型模式,共十一种:策略模式.模板方法模式.观察者模式.迭代子模式.责任链模式.命令模式.备忘录模式.状态模式.訪问者模式.中介者模式.解释器模式. 事实上还有两类:并发型模式和线程池模式. 二.设计模式的六大原则 1.开闭原则(Op

工厂模式

工厂模式属于创建型模式,由一个工厂对象决定创建出哪一种产品类的实例. 角色: IProduct: 产品共同的接口 Product1:具体的产品类 Creator:工厂类,可根据参数决定创建的产品类型 示例: public interface IProduct { void myfunction(); } --- class Product1 implements IProduct{ public void myfunction(){ System.out.println("function1&q

Java设计模式—工厂方法模式&amp;抽象工厂模式

工厂方法模式与抽象工厂模式都是设计模式中重要而且常见的模式.       工厂方法模式:定义一个用于创建对象的接口,让子类决定实例化哪一个类.工厂方法使一个类的实例化延迟到其子类. 通用类图如下: 在工厂方法模式中,抽象产品类Product负责定义产品的共性,实现对事物最抽象的定义:Creator为抽象创建 类,也就是抽象工厂,具体如何创建产品类是由具体的实现工厂ConcreteCreator完成的. 工厂方法模式的扩展方式有很多种,下边是工厂方法模式一个比较实用的源代码: 抽象产品类: pub

java设计模式--工厂模式

总结 (1)简单工厂模式是由一个具体的类去创建其他类的实例,父类是相同的,父类是具体的. (2)工厂方法模式是有一个抽象的父类定义公共接口,子类负责生成具体的对象,这样做的目的是将类的实例化操作延迟到子类中完成. (3)抽象工厂模式提供一个创建一系列相关或相互依赖对象的接口,而无须指定他们具体的类.它针对的是有多个产品的等级结构.而工厂方法模式针对的是一个产品的等级结构. 一.工厂模式主要是为创建对象提供过渡接口,以便将创建对象的具体过程屏蔽隔离起来,达到提高灵活性的目的. 工厂模式在<Java

大话设计模式:简单工厂模式

由于面向过程编程造成的代码膨胀问题越来越严重,使其维护的代价高,灵活性很低.为了使代码易维护.易扩展.易复用和灵活性好,所以我们在采用面向对象编程的时候,防止采用面向对象的语言实际上却做着面向过程的事儿,更需要采用某种设计模式,核心就是使程序变得高内聚,低耦合,这样的程序才能达到上面的四个优点.而简单工厂模式的出现也正是为了达到这样一种效果,将工厂和产品分块,具体解决了实例化那个对象(具体产品)的需求.从而实现了高内聚,低耦合.使程序易维护.易扩展.易复用和灵活性好.同时也用到了面向对象编程的三

大话设计模式:抽象工厂模式

抽象方法模式:提供一个创建一系列相关或互相依赖对象的接口,而无需指定他们具体的类. 三种模式的对比:   简单工厂模式 工厂模式 抽象工厂模式 产品 可以有多个但是都属于同一类, 同一等级.都继承产品抽象类. 可以有多个但是都属于同一类,同一等级. 都继承产品抽象类. 可以有不同种类的产品,每类有多中 具体产品: 抽象产品 只能有一个 只能有一个; 多个抽象产品类:每个抽象产品类可 以派生多种具体产品: 抽象工厂类   只能有一个,可以派生出多个具体工厂类: 只有一个,可派生出多个具体工厂类:

【设计模式】1、抽象工厂模式

对于这个抽象工厂的相应的代码实现 /** * 功能:抽象工厂模式的作用 适用性 1.一个系统要独立于它的产品的创建.组合和表示时. 2.一个系统要由多个产品系列中的一个来配置时. 3.当你要强调一系列相关的产品对象的设计以便进行联合使用时. 4.当你提供一个产品类库,而只想显示它们的接口而不是实现时. * 时间:2016年2月11日22:18 * 作者:cutter_point */ package com.shejimoshi.create.AbstractFactory; public in