设计模式 | 简单工厂模式

简介: 简单工厂模式提供了专门的工厂类用于创建对象,将对象的创建和对象的使用分离开,它作为一种最简单的工厂模式在软件开发中得到了较为广发的应用。

简单工厂模式的概述

说明: 简单工长模式 并不属于 GoF23 种经典设计模式,但通常将它作为学习其他工厂模式的基础。
  • 举例:考虑一个水果农场,当用户需要一种水果时,该农场能够根据用户所提供的水果名称返回该水果。
  • 类比:水果农场(工厂/Factory),农场的水果(产品/Product),水果的名称(参数/arg);

作为最简单的设计模式之一,简单工厂模式的设计思想和实现过程都比较简单,其基本实现流程如下:

  1. 将需要创建的各种不同产品对象的相关代码封装到不同的类中,这些类称为具体产品类,而将它们公共的代码进行抽象和提取后在封装在一个抽象产品类中,每一个具体类都是一个抽象产品类的子类(派生类);
  2. 提供一个工厂类用于创建各种产品,在工厂类中提供一个创建产品的工厂方法,该方法可以根据所传入参数的不同创建不同的具体产品对象;
  3. 客户端只需要用工厂类的工厂方法并传入相应水果的名称参数即可得到一个产品对象;

1.1 简单工厂模式的定义

简单工厂模式(Simple Factory Pattern):定义一个工厂类,它可以根据参数的不同返回不同类的实例,被创建的实例通常都具有共同的父类;

由于在简单工厂模式中用于创建实例的方法通常是静态(static)方法,因此简单工厂模式又被称为 静态工厂方法模式(Static Factory Method), 它是一种 类创建型模式

要点:如果需要什么,只需传入一个正确的参数,就可以获取所有需要的对象,而无需知道该对象的创建细节。

简单工厂模式的结构与实现

2.1 简单工厂模式的结构

由下图可见,简单工厂模式包含以下 3 个角色:

image.png

  • Factory(工厂):工厂角色既工厂类,它是简单工厂模式的核心,负责实现创建所有产品实例对象的内部逻辑;工厂类被外界调用,创建所需的产品对象;在工厂类中提供了静态的工厂方法 FactoryMethod(string arg),返回类型为抽象产品类型 Product。
  • Product(抽象产品角色):它是工厂类所创建的所有对象的父类,封装了各种产品对象的公共方法,它的引入将提高系统的灵活性,使得在工厂类中只需定义一个通用的工厂方法,因为所有创建的具体产品对象都是该子类对象;
  • ConcreteProduct(具体产品对象):他是简单工厂模式的创建目标,所有被创建的对象都充当这个角色的某个具体类的实例。每一个具体产品角色都继承了抽象产品角色,需要实现在抽象产品(父类)中声明的抽象方法。

2.2 简单工厂模式的实现

完整代码实例请查看 :
https://gitee.com/dolayout/DesignPatternOfCSharp/tree/master/DesignPatternOfCSharp/SimpleFactoryPattern

2.3 简化模式结构

有时候为了简化简单工厂模式,可以将抽象产品类和工厂类合并,将静态工厂方法移到抽象产品类中,结构如下图所示:

image.png

上图中,客户端可以通过调用产品父类的静态工厂方法,根据不同参数创建不同类型的产品子类对象,这种方法在很多类库和框架中也广泛使用。

简单工厂模式的优缺点与适用环境

简单工厂模式提供了专门的工厂类用于创建对象,将对象的创建和对象的使用分离开,它作为一种最简单的工厂模式在软件开发中得到了较为广发的应用。

3.1 优点

  • (1)工厂类包含必要的判断逻辑,可以决定在什么时候创建哪一个产品类的实例,客户端可以免除直接创建产品对象的职责.而仅仅“消费”产品,简单工厂模式实现了对象创建和使用的分离。
  • (2)客户端无须知道所创建的具体产品类的类名,只需要知道具体产品类所对应的参数即可,对于一些复杂的类名,通过简单工厂模式可以在一定程度上减少使用者的记忆量。
  • (3)通过引人配置文件,可以在不修改任何客户端代码的情况下更换和增加新的具体产品类,在一定程度 上提高了系统的灵活性。

3.2 缺点

  • (1)由于工厂类集中了所有产品的创建逻辑,职责过重,一且不能正常工作,整个系统都要受到影响。
  • (2)使用简单工厂模式势必会增加系统中类的个数(引人了新的工厂类),增加了系统的复杂度和理解难度。
  • (3)系统扩展困难,一且添加新产品不得不修改工厂逻辑,在产品类型较多时,有可能造成工厂逻辑过于复杂,不利于系统的扩展和维护。
  • (4)简单工厂模式由于使用了静态工厂方法,造成工厂角色无法形成基于继承的等级结构。在C#语言中,不能通过类的实例对象来访问静态方法和静态变量,无法在客户端代码中针对工厂父类编程.而在运行时使用工厂子类对象来覆盖父类,因此,工厂类不能得到很好地扩展。

3.3 适用环境

  • (1)工厂类负责创建的对象比较少,由于创建的对象较少,不会造成工厂方法中的业务逻辑过于复杂。
  • (2)客户端只知道传入工厂类的参数,对于如何创建对象并不关心。
目录
相关文章
|
3天前
|
设计模式 API
【设计模式】适配器和桥接器模式有什么区别
【设计模式】适配器和桥接器模式有什么区别
8 1
|
3天前
|
设计模式
【设计模式】张一鸣笔记:责任链接模式怎么用?
【设计模式】张一鸣笔记:责任链接模式怎么用?
11 1
|
3天前
|
设计模式 uml
【设计模式】建造者模式就是游戏模式吗?
【设计模式】建造者模式就是游戏模式吗?
11 0
|
3天前
|
设计模式 Java uml
【设计模式】什么是工厂方法模式?
【设计模式】什么是工厂方法模式?
8 1
|
3天前
|
设计模式 uml
【设计模式】一文搞定简单工厂模式!
【设计模式】一文搞定简单工厂模式!
8 2
|
3天前
|
设计模式 JavaScript 前端开发
js设计模式-观察者模式与发布/订阅模式
观察者模式和发布/订阅模式是JavaScript中的两种设计模式,用于处理对象间的通信和事件处理。观察者模式中,一个主题对象状态改变会通知所有观察者。实现包括定义主题和观察者对象,以及在主题中添加、删除和通知观察者的功能。发布/订阅模式则引入事件管理器,允许发布者发布事件,订阅者通过订阅接收通知。
|
3天前
|
设计模式 前端开发 Java
19:Web开发模式与MVC设计模式-Java Web
19:Web开发模式与MVC设计模式-Java Web
24 4
|
3天前
|
设计模式 消息中间件 Java
Java 设计模式:探索发布-订阅模式的原理与应用
【4月更文挑战第27天】发布-订阅模式是一种消息传递范式,被广泛用于构建松散耦合的系统。在 Java 中,这种模式允许多个对象监听和响应感兴趣的事件。
39 2
|
3天前
|
设计模式 存储 JavaScript
[设计模式Java实现附plantuml源码~创建型] 多态工厂的实现——工厂方法模式
[设计模式Java实现附plantuml源码~创建型] 多态工厂的实现——工厂方法模式
|
3天前
|
设计模式 Java Go
[设计模式Java实现附plantuml源码~创建型] 集中式工厂的实现~简单工厂模式
[设计模式Java实现附plantuml源码~创建型] 集中式工厂的实现~简单工厂模式