Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >工厂方法模式

工厂方法模式

作者头像
mingmingcome
发布于 2021-11-29 07:26:39
发布于 2021-11-29 07:26:39
23500
代码可运行
举报
运行总次数:0
代码可运行

2018年8月22日19:34:48

工厂方法模式

定义

吾欲娶卿,必问卿之父母,谓之父母之命。

工厂方法模式(Factory Method),定义一个用于创建对象的接口,让子类决定实例化哪一个类。工厂方法使一个类的实例化延迟到其子类。 ——《设计模式:可复用面向对象软件的基础》

使用场景

工厂方法模式在简单工厂模式的基础上,将判断逻辑的选择权上交给客户端,让客户端决定使用哪个具体工厂类。这算是工厂方法相比与简单工厂模式的缺点吧,这样的话,你就要事先知道有什么具体工厂类。相对于直白的new对象,不需要记住具体产品类,服务端隐藏了具体产品类的创建细节,在具体工厂类中不一定就是创建具体产品类,也可以做一些其他事情,符合面向对象的封装性。

简单工厂模式加产品,需要修改内部判断逻辑,这是违反设计模式六大模式中的开闭原则,就是对扩展是开放的,对修改是关闭的。工厂方法模式加产品,只需增加相对应的具体工厂对象即可,符合开闭原则,这是工厂方法模式优点之一。个人观点:工厂方法模式适合那种经常更替(即增加和删除)具体产品对象的场景,正好利用了这个优点。如服装换季,你是一个设计师,换季了新的产品上架,加上新产品,老板选择新工厂,销售商家只需要从工厂获取新产品即可,旧产品下架,和旧工厂合同到期,就这样。

角色

将简单工厂模式的工厂角色内部逻辑判断上交给客户端后,分别封装创建对象细节到具体工厂类,具体工厂类都继承于一个共同的接口。简单工厂模式可查看:简单工厂模式

工厂方法模式有以下四种角色:

  • 抽象工厂角色(IFactory):具体工厂公共接口,定义工厂方法返回产品
  • 具体工厂角色(ConcreteFactoryImpl):继承工厂工厂公共接口,实现工厂方法,运行期返回具体产品实例
  • 抽象产品角色(IProduct)
  • 具体产品角色(ConcreteProductImpl)
图示
代码示例

代码示例依然用的是加减乘除运算操作,跟简单工厂模式一样,只是将工厂类SimpleFactory拆分为抽象工厂类和具体工厂类。简单工厂模式可查看:简单工厂模式

类依赖关系图:

抽象工厂角色(IOperationFactory.java):

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
public interface IOperationFactory {
	public IOperation createOperation();
}

抽象出来的具体工厂对象公共接口。

具体工厂角色(AddOperationFactoryImpl.java、SubOperationFactoryImpl.java、MulOperationFactoryImpl.java、DivOperationFactoryImpl.java):

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// 加法工厂
public class AddOperationFactoryImpl implements IOperationFactory {

	@Override
	public IOperation createOperation() {
		return new AddOperationImpl();
	}

}
// 减法工厂
public class SubOperationFactoryImpl implements IOperationFactory {

	@Override
	public IOperation createOperation() {
		return new SubOperationImpl();
	}

}
//  乘法工厂
public class MulOperationFactoryImpl implements IOperationFactory {

	@Override
	public IOperation createOperation() {
		return new MulOperationImpl();
	}

}
//  除法工厂
public class DivOperationFactoryImpl implements IOperationFactory {

	@Override
	public IOperation createOperation() {
		return new DivOperationImpl();
	}

}

每个具体工厂对象对应一个具体产品对象。

抽象产品角色(IProduct.java):

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
public interface IOperation {
	public int getResult(int a, int b);
}

具体产品角色(AddOperationImpl.java、SubOperationImpl.java、MulOperationImpl.java、DivOperationImpl.java):

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// 加法实现类
public class AddOperationImpl implements IOperation{

	@Override
	public int getResult(int a, int b) {
		return a + b;
	}

}
// 减法实现类
public class SubOperationImpl implements IOperation {
	
	@Override
	public int getResult(int a, int b) {
		return a - b;
	}
}
// 乘法实现类
public class MulOperationImpl implements IOperation {

	@Override
	public int getResult(int a, int b) {
		return a * b;
	}

}
// 除法实现类
public class DivOperationImpl implements IOperation {

	@Override
	public int getResult(int a, int b) {
		return a / b;
	}

}

测试类(FactoryMethodTest.java):

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
public class FactoryMethodTest {
	
	public static void main(String[] args) {
		int a = 999, b = 888;
		// 加
		// 创建具体工厂
		IOperationFactory operationFactory = new AddOperationFactoryImpl();
		// 创建具体产品
		IOperation operation = operationFactory.createOperation();
		// 调用具体产品的功能
		int result = operation.getResult(a, b); // 1887
		System.out.println(result);
		
		// 减
		operationFactory = new SubOperationFactoryImpl();
		operation = operationFactory.createOperation();
		result = operation.getResult(a, b); // 111
		System.out.println(result);
		
		// 乘
		operationFactory = new MulOperationFactoryImpl();
		operation = operationFactory.createOperation();
		result = operation.getResult(a, b); // 887112
		System.out.println(result);
		
		// 除
		operationFactory = new DivOperationFactoryImpl();
		operation = operationFactory.createOperation();
		result = operation.getResult(a, b); // 1
		System.out.println(result);
		
	}
	
}

客户端要判断使用什么具体工厂对象,从而实例化所需的具体产品对象。

优点(小抄)

(链接在文末参考处)

1、在工厂方法模式中,工厂方法用来创建客户所需要的产品,同时还向客户隐藏了哪种具体产品类将被实例化这一细节,用户只需要关心所需产品对应的工厂,无须关心创建细节,甚至无须知道具体产品类的类名。

2、基于工厂角色和产品角色的多态性设计是工厂方法模式的关键。它能够使工厂可以自主确定创建何种产品对象,而如何创建这个对象的细节则完全封装在具体工厂内部。工厂方法模式之所以又被称为多态工厂模式,是因为所有的具体工厂类都具有同一抽象父类。

3、使用工厂方法模式的另一个优点是在系统中加入新产品时,无须修改抽象工厂和抽象产品提供的接口,无须修改客户端,也无须修改其他的具体工厂和具体产品,而只要添加一个具体工厂和具体产品就可以了。这样,系统的可扩展性也就变得非常好,完全符合“开闭原则”。

缺点(小抄)

1、在添加新产品时,需要编写新的具体产品类,而且还要提供与之对应的具体工厂类,系统中类的个数将成对增加,在一定程度上增加了系统的复杂度,有更多的类需要编译和运行,会给系统带来一些额外的开销。

2、由于考虑到系统的可扩展性,需要引入抽象层,在客户端代码中均使用抽象层进行定义,增加了系统的抽象性和理解难度,且在实现时可能需要用到DOM、反射等技术,增加了系统的实现难度。

总结

工厂方法模式是简单工厂模式的进一步抽象和推广。

由于使用了面向对象的多态性,工厂方法模式保持了简单工厂模式的优点,而且克服了它的缺点。

所有代码可见于Github.Mingmingcome

参考:

工厂方法模式(Factory Method Pattern)

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018-08-23 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
第八话-工厂方法模式
工厂方法模式和简单工厂模式除了工厂类不同之外其它都一样。 二、有了简单工厂模式为什么还用工厂方法模式? 简单工厂模式似乎非常easy。正由于如此。他的工厂类违背了设计模式中的开放封闭原则。以第一话中的计算器为例。每次添加一个新的操作时都要更改工厂类里的switch分支。
全栈程序员站长
2022/07/06
1510
第八话-工厂方法模式
设计模式:工厂方法模式(Factory Method)
工厂方法模式是一种 创建型设计模式,其核心思想是 将对象的创建过程延迟到子类,让子类决定实例化哪个具体类。
用户11531739
2025/03/05
1390
简单工厂模式
简单工厂模式(Simple Factory Pattern):又称为静态工厂方法(Static Factory Method)模式。设计模式分为创建型模式、结构型模式、行为型模式,简单工厂模式属于创建型模式。在简单工厂模式中,可以根据参数的不同返回不同类的实例。简单工厂模式专门定义一个类来负责创建其他类的实例,被创建的实例通常都具有共同的父类。
mingmingcome
2021/11/29
2710
简单工厂模式
工厂方法模式
高爽
2017/12/28
5660
工厂方法模式
设计模式之三(工厂方法模式)
工厂方法模式:定义一个用于创建对象的接口,让子类决定实例化那一个类。工厂方法使一个类的实例化延迟到其子类。
aehyok
2018/09/11
3980
设计模式之三(工厂方法模式)
设计模式之工厂三兄弟
简单工厂模式(Simple Factory Pattern):又称为静态工厂方法(Static Factory Method)模式,它属于类创建型模式。在简单工厂模式中,可以根据参数的不同返回不同类的实例。简单工厂模式专门定义一个类来负责创建其他类的实例,被创建的实例通常都具有共同的父类。
特特
2022/11/28
7431
设计模式之工厂方法模式
工厂方法模式(Factory Method),是23种设计模式之一。DP中是这么定义工厂方法模式的:
端碗吹水
2020/09/23
3060
设计模式之工厂方法模式
[设计模式]简单工厂模式
该文讲述了如何利用简单工厂模式实现具有加减乘除功能的计算器,并介绍了简单工厂模式的结构、特点和优缺点,以及测试代码和运行结果。
静默虚空
2018/01/05
5030
[设计模式]简单工厂模式
[设计模式]工厂方法模式
简介 工厂方法模式 (Factory Method)定义一个用于创建对象的接口,让子类决定实例化哪一个类。工厂方法使一个类的实例化延迟到其他子类。  工厂模式是一种类创建型模式 (可参考 设计模式 创
静默虚空
2018/01/05
6150
[设计模式]工厂方法模式
工厂方法模式浅析
在平时的应用开发中,工厂模式是比较常用的一个设计模式,基本上在很多的开源jar中可以看到工厂设计模式的影子。
孟君
2020/07/16
4550
设计模式(八):工厂方法模式
定义用于创建对象的接口,让子类决定创建哪个类的实例。工厂方法允许类的实例化延迟到子类。
xujjj
2019/07/12
3940
设计模式(八):工厂方法模式
工厂方法模式 创建型 设计模式(三)
核心的工厂角色,不再是具体的工厂,也就是不再负责所有具体产品的创建,进一步转变为抽象角色。
noteless
2018/12/12
3610
工厂方法模式
上文描述了简单工厂模式,但是简单工厂模式并不属于23种设计模式。所以本文我们介绍简单工厂模式的高级实现。在此之前先看一下简单工厂模式所存在的问题。预留问题:
乱敲代码
2020/05/21
3450
设计模式 -- 工厂方法模式
工厂方法模式和简单工厂十分类似,大致结构是基本类似的。不同在于工厂方法模式对工厂类进行了进一步的抽象,将之前的一个工厂类抽象成了抽象工厂和工厂子类,抽象工厂定义一个创建抽象子类的接口,抽象工厂的子类实现这些接口并决定实例化哪个抽象子类。工厂子类决定着创建哪个抽象子类,外界决定着创建哪种工厂子类,抽象子类和工厂子类是一一对应的
xy_ss
2023/11/22
1410
设计模式 -- 工厂方法模式
设计模式之工厂方法模式
工厂方法模式(Factory Method Pattern) 隶属于设计模式中的创建型模式,前面的简单工厂模式是工厂方法模式的简化版,因此两者在很多方面都是相似的。
Dylan Liu
2019/08/07
4260
设计模式-工厂方法模式
在简单工厂模式中,我们发现存在很多问题: 由于工厂类集中了所有产品创建逻辑,一旦不能正常工作,整个系统都要受到影响。 要新增产品类的时候,就要修改工厂类的代码,违反了开放封闭原则(对扩展的开放,对修改的关闭)。 简单工厂模式由于使用了静态工厂方法,造成工厂角色无法形成基于继承的等级结构。 为了解决上述的问题,我们学习一种新的设计模式:工厂方法模式。 模式定义 定义一个用于创建对象的接口,让子类决定实例化哪一个类。工厂方法使一个类的实例化延迟到其子类。 设计原则 依赖倒置原则:要依赖抽象,不要依赖具体类。
武培轩
2018/04/18
5360
设计模式-工厂方法模式
设计模式|工厂方法模式
工厂方法模式是类的创建模式,又叫做虚拟构造子(Cirtual Constructor)模式或者多态工厂(Polymorphic Factory)模式。 工厂方法模式的用意是定义一个创建产品对象的工厂接口,将实际创建工作推迟到子类中。
技术从心
2019/08/06
3260
设计模式|工厂方法模式
JAVA设计模式2:工厂方法模式,将对象的实例化过程封装在子类
本文讲解了 Java 设计模式中的工厂方法模式,并给出了样例代码,工厂方法模式是一种创建型设计模式,它提供了一种将对象的实例化过程封装在子类中的方式。
Designer 小郑
2023/08/02
3350
JAVA设计模式2:工厂方法模式,将对象的实例化过程封装在子类
php 开发模式之工厂模式
以下内容转载自:http://blog.csdn.net/zhengzhb/article/details/7359385
全栈程序员站长
2022/09/19
2380
php 开发模式之工厂模式
『设计模式』工厂方法模式
每次增加一个产品时,都需要增加一个具体类和对象实现工厂,使得系统中类的个数成倍增加,在一定程度上增加了系统的复杂度,同时也增加了系统具体类的依赖。
风骨散人Chiam
2020/10/28
4440
相关推荐
第八话-工厂方法模式
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验