设计模式-工厂模式

工厂顾名思义就是创建产品,本质就是用工厂方法代替new操作创建一种实例化对象的方式。根据不同的实现方式和抽象级别又可分为简单工厂,工厂方法和抽象工厂三种模式。

案例


需求

封装一个SqlHelper类,实现对SqlServer的操作,且后续可能需要同时支持SqlServer,MySql,Oracle等主流数据库。

这是我们平常非常熟悉的需求了,根据需求我们可以得到如下类图:

简单工厂


UML类图

我们将前面SqlHelper例子中的类图进行一次抽象,就得到更通用的简单工厂模式类图了。其中对应关系如下:

  • Client:SqlHelper

  • SimpleFactory:DbConnectionFactory

  • AbstractProduct:DbConnection

  • Product1、Product2:SqlConnection、MySqlConnection

定义

简单工厂模式是由一个工厂对象决定创建出哪一种产品类的实例。由于简单工厂通常会使用静态方法实现,因此也叫做静态工厂模式,它不属于23种GOF设计模式之一。

优缺点

  • 优点

    • 实现了对责任的分割,隔离了变化,因为它提供了专门的工厂类用于创建对象。

    • 通过配置文件,可以在不修改任何客户端代码的情况下更换和增加新的具体产品类,在一定程度上提高了系统的灵活性。

  • 缺点

    • 集中了所有实例的创建逻辑,违反了单一职责原则

    • 扩展困难,一旦添加新产品就不得不修改工厂逻辑,违反了开闭原则

工厂方法


案例改进

由于简单工厂模式不满足开闭原则,因此,我们需要对其进行改进,将简单工厂进行一次抽象,然后让每个具体的工厂子类负责生产对应的产品,具体改进如下:

UML类图

同样的,我们进行一次抽象,就得到工厂方法模式的类图了。

定义

定义一个工厂父类,工厂父类负责定义创建对象的公共接口,而子类则负责生成具体的对象。即将类的实例化延迟到工厂类的子类中完成,即由子类来决定应该实例化哪一个类。

优缺点

  • 优点: 满足各种设计原则

  • 缺点:类的个数成倍增加,增加了系统的复杂度

抽象工厂


需求扩展(参数化查询)

当然,我们知道,工作中,更通用SqlHelper没有这么简单,比如,我们至少需要参数化查询,防止用户的SQL脚本注入攻击。根据工厂方法模式的思路进一步改进,如下图所示:

不难发现,随着需求的增加,会出现如下问题:

  • 类的数量成倍增长

  • 无法保证类之间的依赖关系

改进

基于这些问题,我们继续改进,将多个相互关联的工厂(DbConnect和DbParameter使用时通常有密切联系)合并,得到如下类图:

UML类图

总结出更抽象的类图如下:

定义

抽象工厂是工厂方法的升级版,为相关或者相互依赖的对象提供一个统一的接口,而且无需指定他们的具体实现类。

优缺点

  • 优点

    • 对产品族进行约束,封装性好

  • 缺点

    • 产品族扩展困难,添加一个产品需要修改抽象和具体工厂类,违背开闭原则。

总结

简单工厂模式由于违背了众多设计原则,因此,很多时候会被视为是一种反模式而不是设计模式,但是由于面向对象设计语言中反射机制的存在,使得简单工厂模式使用的反而最为广泛;

工厂方法虽然时最满足设计原则的,但是由于它会使系统变得过于复杂,因此,反而用的最少;

抽象工厂模式更多体现的对产品族的约束,同时,相对于工厂方法模式,也降低了系统的复杂度,极端情况下,如果抽象工厂模式中的产品族只有一个产品,那么抽象工厂模式也就退化成了工厂方法模式。因此,很多人说抽象工厂模式是工厂的工厂,此观点是值得商榷的。

源码链接

(0)

相关推荐

  • Java面试题总结之OOA/D,UML,和XML

    全文字数:   2732 阅读时间:   大约9 分钟 1.UML 是什么?常用的几种UML图? 统一建模语言(Unified Modeling Language,UML)又称标准建模语言:常用图包括 ...

  • 谈谈Java常用类库中的设计模式 - Part Ⅰ

    背景 最近一口气看完了Joshua Bloch大神的Effective Java(下文简称EJ).书中以tips的形式罗列了Java开发中的最佳实践,每个tip都将其意图和要点压缩在了标题里,这种做法 ...

  • PHP设计模式—工厂模式之简单工厂模式

    定义: 简单工厂模式:将调用者和创建者分离,实现解耦,调用者直接向工厂请求,通过工厂去选择需要实例化的对象,用一个单独的类来做这个创建实例的过程. 代码实例: 问题:假设一个关于个人事务管理的项目中有 ...

  • java设计模式----工厂模式

    简单工厂模式 简单工厂模式不是 23 种里的一种,简而言之,就是有一个专门生产某个产品的类. 比如下图中的鼠标工厂,专业生产鼠标,给参数 0,生产戴尔鼠标,给参数 1,生产惠普鼠标. 工厂模式 工厂模 ...

  • 创建型设计模式--工厂模式、抽象工厂模式

    一.小案例分析 1.功能需求: 实现一个发送信息的功能,要便于扩展与维护. (1)发送信息的工具有很多,比如短信.微信.邮件.QQ等. (2)选择某个工具进行信息发送. 2.小菜鸡去实现: (1)定义 ...

  • PHP设计模式之简单工厂模式

    PHP设计模式之简单工厂模式 先从简单工厂入门,不管是面试还是被他人面试,在问到设计模式的时候,大多数人都会提到工厂模式.毫无疑问,工厂相关的几种模式在设计模式中是最出名的也是应用比较广泛的一种模式. ...

  • PHP设计模式之抽象工厂模式

    PHP设计模式之抽象工厂模式 工厂模式系列中的重头戏来了,没错,那正是传闻中的抽象工厂模式.初次听到这个名字的时候你有什么感觉?反正我是感觉这货应该是非常高大上的,毕竟包含着"抽象" ...

  • [PHP小课堂]PHP设计模式之简单工厂模式

    PHP设计模式之工厂方法模式 关注公众号:[硬核项目经理]获取最新文章 添加微信/QQ好友:[DarkMatterZyCoder/149844827]免费得PHP.项目管理学习资料

  • [PHP小课堂]PHP设计模式之抽象工厂模式

    [PHP小课堂]PHP设计模式之抽象工厂模式 关注公众号:[硬核项目经理]获取最新文章 添加微信/QQ好友:[DarkMatterZyCoder/149844827]免费得PHP.项目管理学习资料

  • 设计模式——把类作为参数的抽象工厂模式

    今天给大家介绍一个非常简单的设计模式,一学就会,非常好用. 这个模式叫做抽象工厂模式,大家可能对工厂模式比较熟悉,在工厂模式当中封装了实例的创建逻辑.主要的用途一般是将一些复杂的类的创建过程整合在一起 ...

  • 【C++设计模式二】C++工厂模式

    (1)定义 简单工厂模式中,每新增一个具体产品,就需要修改工厂类内部的判断逻辑.为了不修改工厂类,遵循开闭原则,工厂方法模式中不再使用工厂类统一创建所有的具体产品,而是针对不同的产品设计了不同的工厂, ...