【设计模式】创建者模式之 工厂方法 抽象工厂

工厂方法模式(Factory Method)

一个特定功能,往往有多种实现方式,但是很难有某一个实现可以适用于所有情况,因此往往需要根据特定的场景选择不同的实现。试想:把选择具体实现的代码放在业务中会发生什么?每当我们需要一个新的功能拓展时,就要改动业务代码,但是这样违背了OCP,引入工厂方法模式可以解决这样的问题。

意图(Intent)

工厂方法模式:一种创建者模式,提供了一个创建类的接口,具体创建该类的哪种实现类,由传入的子类工厂决定

工厂方法模式其实就是对子类构造的封装。

工厂是对创建类的接口一种隐喻。我们把需求传递给工厂,工厂就能构造出一个相对应的子类

可以直接在工厂中加入产品的方法,这样就可以直接通过工厂使用产品方法,而不需要再调用产品

结构(Structure)

工厂方法模式的结构图如下:

在这里插入图片描述

  • CreatorProductProduct的工厂,它包含了一个构造Product的方法和Product内部的方法
  • ConcreProductAConcreProductBProduct的实现类,每个类都有一个对应的工厂子类
  • 工厂接口只负责定义工厂的行为,工厂的具体行为,由对应实现类的子类负责实现

为什么需要工厂方法模式?

工厂方法模式的必要性可以从多个维度解释,本文提供了其中两种解释:

  1. 首先我们要明确一个概念,客户端只通过接口使用产品,而不需要知道其中的细节,我们作为开发者也不想让客户端知道这些细节。工厂方法模式就可以理解为一种创建产品的接口,这个产品内部可能需要各种各样的属性,来实现产品的功能,客户端传入的数据怎么分配在该产品的属性中不是客户端需要知道的。

  2. 而从OCP的角度来看,如果没有工厂接口,每次新增加一个产品类,我们就要重新在客户端加入一段代码,实现该产品的创建,这个显然违背了OCP。

实现方式(implement)

  1. 为要实现的功能创建一个接口或者抽象类
  2. 为这个接口或抽象类创建一个工厂接口
  3. 用不同的子类实现这个接口或抽象类
  4. 为每个子类编写工厂接口的实现工厂类
  5. 在创建子类实例时,调用对应的工厂类的方法即可

优缺点(Pros & Cons)

  • 可以避免客户端和具体产品的高耦合

  • 保证SRP,选择并创建具体产品的工作交给工厂

  • 保证OCP,当有新的实现类的时候,只需要继承父类即可,不用改变客户端代码

  • 代码过于复杂,并且可能造成类爆炸

抽象工厂(Abstract Factory)

工厂方法模式为我们提供了每种产品的实现方法,解耦了客户端和具体产品的紧密关联,但是过于冗杂的类会让我们对项目管理的难度大大提升,为了解决这个问题,我们可以使用抽象工厂模式。

意图(Intent)

抽象工厂是对不同产品的抽象。就像我们可以通过学生的共有特性抽象出学生类一样,抽象工厂将具有某种相同特性的产品抽象到了一个类,这个类中有多个工厂方法。

工厂方法不是一个类!上文似乎把工厂方法作为一个类在讲解,这其实是为了简化工厂方法模式的讲解,而只在类中声明了工厂方法一个方法。

举个例子来讲,一套衣服包括了上衣和裤子。那么一个抽象工厂中就包含了两个工厂方法,一个用于生产上衣,一个用于生产裤子。

结构(Structure)

抽象工厂的结构图如下:

在这里插入图片描述

  • 抽象工厂负责建造两种产品:ProductAProductB
  • 定义一个抽象工厂的接口
  • 根据产品的不同风格实现抽象工厂接口

为什么需要抽象工厂模式?

抽象工厂模式是对工厂方法模式的一种拓展,一个抽象工厂类应该包含多种工厂方法,这样可以让类的管理更有逻辑性,也能对相似风格的不同产品进行抽象。

优缺点(Pros & Cons)

  • 具有工厂方法的优点

  • 可以保证来自同一工厂的不同产品是兼容的

  • 可以减少工厂方法带来的类爆炸

  • 使类的管理更清晰

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/670016.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

09 华三 SSH

03 华三SSH 远程登录 1 AI解说官网 Kimi.ai - 帮你看更大的世界 (moonshot.cn) 华三交换机的SSH配置主要目的是通过SSH协议实现安全的远程登录和管理,以确保数据传输的安全性。以下是配置SSH的一般步骤和思路: 生成密钥对:首先需要在交换…

Sharding Capital: 为什么投资全链流动性基础设施 Entangle ?

写在前面:Entangle 项目的名称取自于量子纠缠(Quantum entanglement),体现了项目对于构建连接、关联和互通的愿景。就像量子纠缠将不同的粒子联系在一起,Entangle 旨在通过其跨链流动性和合成衍生品的解决方案将不同的区块链网络连接在一起&a…

[开发|鸿蒙] 鸿蒙OS开发环境搭建(笔记,持续更新)

搭建开发环境流程: https://developer.huawei.com/consumer/cn/doc/harmonyos-guides-V2/installation_process-0000001071425528-V2 鸿蒙DevEco Studio 3.1.1 Release仅支持windows和mac系统 运行环境要求 为保证DevEco Studio正常运行,建议电脑配置…

炒股自动化:散户如何通过API查询资产和持仓,Python接口

券商官方的接口,个人账户可申请,入金门槛低,接入文档完善,技术支持好的,经过我们筛选后,只有一家符合,会编程,有基础,只是需要API接口的朋友不用看这些内容,不…

SpringBoot自动连接数据库的解决方案

在一次学习设计模式的时候,沿用一个旧的boot项目,想着简单,就把数据库给关掉了,结果报错 Consider the following: If you want an embedded database (H2, HSQL or Derby), please put it on the classpath. 没有数据库的需…

【Unity 协程】

Unity中的协程(Coroutine)是一种编程结构,它允许你以一种看似同步的方式编写可能需要异步执行的代码。协程特别适用于需要在一定时间后执行操作,或者在循环执行某段代码直到某个条件满足时的场景。 协程使用IEnumerator委托来实现…

1-38 流资源类结构

一 简介 1. Java中所说的流资源--IO流 2.为什么学习留资源? --要操作文件中的数据 将数据写入指定的文件 将数据从指定的文件读取 3.分类 -- 四大基流 , 八大子流 (重点) 按照流向分 : 输入流 和输出流 按照操作数据资源的类型划分 字符流 (重点) Reader -- 字符…

【挑战30天首通《谷粒商城》】-【第一天】01、简介-项目介绍

文章目录 课程介绍一、 项目介绍1、项目背景A、电商模式1、B2B 模式2、B2C 模式3、C2B 模式4、C2C 模式5、O2O 模式 1.2、项目架构图1.3、项目技术 & 特色1.4、项目前置要求二、分布式基础概念(略)三、环境撘建(略) one more thing 课程介绍 1.分布式基础(全栈开发篇)2.分…

帮助命令

1.man 原意:manual 所在路径:/usr/bin/man 执行权限:所有用户 语法:man [命令或配置文件] 功能描述:获得帮助信息 例:$ man ls 查看ls命令的帮助信息 查看命令的帮助主要是看这个命令是干什么用的&am…

Honor of Kings QQ 1537937510

司空震到底要不要物理伤害高呢?还是法术伤害高呢?要不要出魔女和制裁引发的血案 先看下司空震的说明: 说下这个伙计为啥加QQ来骂我,因为这场当然最终是赢了,比赛里他一直强调司空震是物理伤害改版问题,然后…

asp.net朱勇项目个人博客(3)

引文:按照书上的项目,我们最后实现管理端的三个增删改查的功能即可,相对与三个增删改查,文章,分类和留言,这里我们所需要用的的关联的一个表就是文章表,因为文章表每一个文章的增加显示和修改都需要对应的一个分类&…

数据结构-AVL树

目录 什么是 AVL 树 ASL 度量查找效率 结构体定义 平衡调整 调整类型 左旋和右旋 右旋 左旋 左、右平衡调整 左平衡调整 右平衡调整 插入数据 模拟建立 AVL 树 什么是 AVL 树 二叉排序树的形状取决于数据集,当二叉树的高度越小、结构越合理&#xff0c…