工厂模式
- 创建型模式
- 面向接口编程,体现了面向对象的思想;
- 将创建对象的工作转移到了工厂类
简单工厂模式( Simple Factory Pattern)
简单工厂是产品的工厂
- 简单工厂模式是创建型模式,但不属于23 GOF23种设计模式。
- 由工厂决定生产哪一种类型的产品,适用于工厂类负责创建的对象较少的场景。
- 客户端只需告诉工厂需要生产什么参数的对象,不关心对于生产对象的逻辑。
优点
- 用户只需要传入正确的参数,不需要关心创建过程。
缺点
-
工厂类的指责过重,不适合创建对象类型多的场景,
-
类内部逻辑偏多(违背了单一职责原则)
-
新增产品时可能存在需要修改工厂类的判断逻辑的情况(违背了开闭原则)。
工厂方法模式
工厂方法是工厂的工厂
工厂方法模式(Factory Method Pattern)是指定义一个创建对象的接口,但让实现这个接口的类来决定实例化哪个类,工厂方法让类的实例化推迟到子类中进行。
可参考log4j,
适用场景
-
创建对象需要大量重复的代码
-
客户端(应用层)不依赖与产品类实例如何被创建、实现等细节。
-
一个类通过其子类来指定创建那个对象。
优点
-
用户只需要关心所需产品对应的工厂,无需关心创建细节。
-
加入新产品符合开闭原则,提高了系统的可拓展性。
缺点
-
类的个数容易过多,增加了代码结构的复杂度。
-
增加了系统的抽象性和理解难度。
实例
- ava.util.Calendar, ResourceBundle and NumberFormat getInstance() 使用了工厂方法模式;
- valueOf() 在包装类中,如Boolean, Integer 也使用了工厂方法模式;
抽象工厂(Abstract Factory Pattern)
复杂产品的工厂
产品等级结构
- 产品等级结构即产品的继承结构**,如一个抽象类是电视机,其子类有海尔电视机、海信电视机、TCL电视机,则抽象电视机与具体品牌的电视机之间构成了一个产品等级结构,抽象电视机是父类,而具体品牌的电视机是其子类。
产品族
- 在抽象工厂模式中,产品族是指由同一个工厂生产的,位于不同产品等级结构中的一组产品**,如海尔电器工厂生产的海尔电视机、海尔电冰箱,海尔电视机位于电视机产品等级结构中,海尔电冰箱位于电冰箱产品等级结构中,**海尔电视机、海尔电冰箱构成了一个产品族。
- 一个具体工厂可以生产一个产品族
适用场景
-
客户端(应用层)不依赖与产品类实例如何被创建、实现等细节。
-
强调一系列相关的产品对象(属于同一产品族)
优点
-
完全遵循单一职责原则,具体产品在应用层代码隔离,无需关心创建细节。
-
将一个系列的产品族统一到一起创建。当一个产品族中的多个对象被设计成一起工作时,它能保证客户端始终只使用同一个产品族中的对象。
缺点
-
规定了所有可能被创建的产品集合,产品族中扩展新的产品困难,需修改抽象工厂的接口。
-
增加了系统的抽象性和理解难度。
-
产品族扩展非常困难,要增加一个系列的某一产品,既要在抽象的 Creator 里加代码,又要在具体的里面加代码。
注意事项
- 产品族难扩展,产品等级易扩展。
实例
log4j : LoggerFactory.getLogger("");
Spring : AbstractFactory
AnnotationApplicationConnext