设计模式-工厂模式-1-2

简介: 【6月更文挑战第11天】工厂模式用于封装对象创建,但当load函数与工厂类耦合时,问题出现。为解决此问题,引入了工厂的工厂,如`RuleConfigParserFactoryMap`,它创建并缓存工厂对象,简化了代码修改。然而,过多的Factory类会增加复杂性,简单工厂模式在此类应用中更为适用。当对象创建逻辑复杂,需组装其他对象或避免if-else时,采用工厂方法模式。抽象工厂则处理多维度分类的对象创建。总结:工厂模式的核心价值在于封装变化、代码复用、隔离复杂性和控制复杂度,适用于创建逻辑复杂的情况,否则直接使用new操作即可。

但是实际上上述的方法存在很大的问题,在使用这些工厂类的时候,如何写load函数呢?


2024-06-12-20-29-39-image.png

工厂类对象的创建逻辑又耦合进了load函数里,跟最初的代码版本很相似。那么怎么解决这个问题呢?

可以为工厂类再创建一个简单工厂,也就是工厂的工厂,用来创建工厂类对象。代码如下,其中RuleConfigParserFactoryMap类是创建工厂对象的工厂类,RuleConfigParserFactoryMap返回的是缓存好的单例工厂对象。
2024-06-12-20-32-33-image.png


2024-06-12-20-32-51-image.png

当我们需要添加新的规则配置解析器时,我们只需要创建新的parser类和parser factory类,并且在RuleConfigParserFactoryMap类里,将新的parser factory对象添加到cachedFactories里即可,代码的改动很少,基本上符合开闭原则。

实际上,对于规则配置文件解析这个应用场景来说,工厂模式需要额外创建诸多Factory类,也会增加代码的复杂性。而且,每个Factory类只是做简单的new操作,功能单薄,也没必要设计成独立的类。所以在这个应用场景下,简单工厂模式简单好用,比工厂方法模式更加合适。

思考:什么时候该用工厂方法模式,而非简单工厂模式?

对象的创建逻辑比较复杂,不是简单的new一下就可以,而是要组装其他类对象,做各种初始化操作的时候,推荐使用工厂方法模式,将复杂的创建逻辑拆分到多个工厂类中,让每个工厂类都不至于过于复杂。

某些场景下,如果对象不可复用,工厂类每次都要返回不同的对象,如果用简单工厂模式实现,就只能选择第一种包含if分支逻辑的实现方式。如果我们还想避免烦人的if-else分支逻辑,就推荐使用工厂方法模式

抽象工厂

在简单工厂和工厂方法中,类只有一种分类方法。比如在规则配置解析的例子里,解析器类只会根据配置文件格式(Json,xml,yaml)来分类。但是,如果类又两种分类方式。比如,我们既可以按照配置文件格式来分类,也可以按照解析的对象(Rule规则配置还是System系统配置)来分类,就会对应下面8个parser类。
2024-06-12-20-43-40-image.png

针对这种特殊的场景,如果还是继续用工厂方法来实现的话,我们要针对每个parser都编写一个工厂类,也就是要编写8个工厂类。如果未来还要增加针对业务配置的解析器,比如IBizConfigParser,还需要再增加4个工厂类。

抽象工厂就是针对这种非常特殊的场景而诞生的,我们可以让一个工厂负责创建多个不同类型的对象(IRuleConfigParser、ISystemConfigParser 等),而不是只创建一种parser对象。
2024-06-12-20-48-54-image.png


2024-06-12-20-49-01-image.png

目录
相关文章
|
7月前
|
设计模式
设计模式【二】:工厂模式
设计模式【二】:工厂模式
49 0
|
设计模式 Java C++
设计模式之工厂模式详解和应用
设计模式之工厂模式详解和应用
70 0
|
6月前
|
设计模式 数据格式 XML
设计模式-工厂模式-1-1
【6月更文挑战第10天】本文介绍了工厂模式的两种主要类型:简单工厂和工厂方法。简单工厂模式通过工厂类动态创建对象,例如根据配置文件后缀选择不同解析器。为提高可读性和复用性,可将创建逻辑封装到独立类中。当需添加新解析器时,可能涉及对工厂类的修改,但这在偶尔调整时可接受。工厂方法模式则通过多态消除if分支,增加扩展性,更符合开闭原则。当需要新增解析器时,只需创建实现特定接口的新工厂类。
34 2
设计模式-工厂模式-1-1
|
7月前
|
设计模式 消息中间件 Java
设计模式之工厂模式(C++)
设计模式之工厂模式(C++)
94 0
|
7月前
|
设计模式 算法 uml
C++设计模式(工厂模式)
C++设计模式(工厂模式)
112 1
C++设计模式(工厂模式)
|
7月前
|
设计模式 前端开发 API
【设计模式】之工厂模式
工厂模式是一种常用的创建对象的设计模式,它通过封装对象的创建逻辑,提供统一的接口,实现了代码的解耦和可扩展性。在实际开发中,可以根据具体需求选择是否使用工厂模式来创建对象。工厂模式可以应用于任何需要创建对象的场景。通过使用工厂模式,我们可以提高代码的可维护性、可扩展性和可测试性,使得代码更加灵活和易于理解。
79 0
|
设计模式 Java C#
设计模式之工厂模式(2)
接着,我们定义一个抽象工厂类AbstractFactory,它有两个抽象方法createShape和createColor,分别返回一个Shape对象和一个Color对象: java
57 0
|
设计模式
设计模式之工厂模式
设计模式之工厂模式
65 0
|
设计模式
【设计模式】工厂模式
【设计模式】工厂模式
|
设计模式 SQL 搜索推荐
设计模式之工厂模式(二)
设计模式之工厂模式
115 0