当前位置: 首页 > news >正文

设计模式(十) - 工厂方式模式

前言

在此前的设计模式(四)简单工厂模式中我们介绍了简单工厂模式,在这篇文章中我们来介绍下工厂方法模式,它同样是创建型设计模式,而且又有些类似,文章的末尾会介绍他们之间的不同。

1.工厂方法模式简介

工厂方法模式定义

定义一个用于创建对象的接口,让子类决定实例化哪个类。工厂方法使一个类的实例化延迟到其子类。

工厂方法模式UML图

找了下网上的UML图,都画的丑丑的,自己画吧,结果就出来这么一个更丑的UML图:

Vl4ZnO.png

  • Product:抽象产品类。
  • ConcreteProduct:具体产品类,实现Product接口。
  • Factory:抽象工厂类,该方法返回一个Product类型的对象。
  • ConcreteFactory:具体工厂类,返回ConcreteProduct实例。

2.工厂方法模式简单实现

参考设计模式(四)简单工厂模式这篇文章,我接着举电脑生产的例子。

创建抽象产品

电脑产品类,它有一个start方法用于启动电脑:

public abstract class Computer{public abstract void start();
}

创建具体产品

具体的电脑产品分别是联想、惠普和华硕电脑:

public class LenovoComputer extends Computer {@Overridepublic void start() {System.out.println("联想电脑启动");}
}

public class HpComputer extends Computer {@Overridepublic void start() {System.out.println("惠普电脑启动");}
}

public class AsusComputer extends Computer{@Overridepublic void start() {System.out.println("华硕电脑启动");}
}

创建抽象工厂

里面有一个createComputer方法,想生产哪个品牌的电脑就生产那个:

public abstract class ComputerFactory {public abstract <T extends Computer> T createComputer(Class<T> clz);
}

具体工厂

广达代工厂是一个具体的工厂,他继承抽象工厂,通过反射来生产不同厂家的电脑:

/*** 广达代工厂*/
public class GDComputerFactor extends ComputerFactory {@Overridepublic <T extends Computer> T createComputer(Class<T> clz) {Computer computer=null;String classname=clz.getName();try {//通过反射来生产不同厂家的电脑computer= (Computer) Class.forName(classname).newInstance();} catch (Exception e) {e.printStackTrace();}return (T) computer;}
}

客户端调用

public class Client {public static void main(String[]args) {ComputerFactory computerFactory = new GDComputerFactor();LenovoComputer mLenovoComputer=computerFactory.createComputer(LenovoComputer.class);mLenovoComputer.start();HpComputer mHpComputer=computerFactory.createComputer(HpComputer.class);mHpComputer.start();AsusComputer mAsusComputerr=computerFactory.createComputer(AsusComputer.class);mAsusComputerr.start();}
}

结构很简单,看看下面的UML图就更加容易理解了:

Vl4eBD.jpg

3.工厂方法与简单工厂

简单工厂模式我们都知道,在工厂类中包含了必要的逻辑判断,根据不同的条件来动态实例化相关的类,对客户端来说,去除了与具体产品的依赖,与此同时也会带来一个问题:如果我们去增加产品,比如我们要生产苹果电脑,那我们就需要在工厂类中在添加一个Case分支条件,这违背了开放封闭原则,我们对修改也开放了,不理解开放封闭的原则的同学可以查看设计模式(一)设计六大原则 这篇文章。而工厂方法模式就没有违背这个开放封闭原则,如果我们需要生产苹果电脑,并不需要去修改工厂类,直接创建产品就好了。

http://www.lryc.cn/news/307061.html

相关文章:

  • http协议基础与Apache的简单介绍
  • RabbitMQ的死信队列和延迟队列
  • PyQt 逻辑与界面分离
  • opengl播放3d pose 原地舞蹈脚来回飘动
  • Linux环境基础开发工具使用篇(三) git 与 gdb
  • mybatis---->tx中weekend类
  • Shell echo、printf、test命令
  • 腾讯云主机Ubuntu22.04安装Odoo17
  • conda常用命令详解
  • Java面试——锁
  • Spring Boot与Netty:构建高性能的网络应用
  • ARMv8-AArch64 的异常处理模型详解之异常处理详解(同步异常和异步异常的分析和处理)
  • Elasticsearch:基于 Langchain 的 Elasticsearch Agent 对文档的搜索
  • 学习python的第7天,她不再开放她的听歌榜单
  • 多维时序 | Matlab实现CPO-BiTCN-BiGRU冠豪猪优化时间卷积神经网络双向门控循环单元多变量时间序列预测模型
  • 低代码与大语言模型的探索实践
  • element导航菜单el-menu添加搜索功能
  • 浅析SpringBoot框架常见未授权访问漏洞
  • PostgreSQL内存上下文系统设计概述
  • C++ 网络编程学习二
  • SpringMVC 学习(四)之获取请求参数
  • 多模态表征—CLIP及中文版Chinese-CLIP:理论讲解、代码微调与论文阅读
  • Git本地分支关联远程分支
  • [FT]chatglm2微调
  • AI赋能Oracle DBA:以自然语言与Oracle数据库互动
  • Django学习记录04——靓号管理整合
  • AD9226 65M采样 模数转换
  • 远程控制桌面,让电脑办公更简单
  • 猫头虎分享已解决Bug || 网络连接问题:NetworkError: Failed to fetch
  • Layer1 明星项目 Partisia Blockchain 何以打造互操作、可创新的数字经济网络