2.4 抽象工厂
抽象工厂abstract factory
1 概念
别名
- Kit
意图
提供一个创建一系列相关或相互依赖对象的接口,而无需指定它们具体的类。
结构
抽象工厂模式创建的是对象家族,也就是很多对象而不是一个对象,并且这些对象是相关的,也就是说必须一起创建出来。而工厂方法模式只是用于创建一个对象,这和抽象工厂模式有很大不同。
抽象工厂模式用到了工厂方法模式来创建单一对象,AbstractFactory 中的 createProductA() 和 createProductB() 方法都是让子类来实现,这两个方法单独来看就是在创建一个对象,这符合工厂方法模式的定义。
至于创建对象的家族这一概念是在 Client 体现,Client 要通过 AbstractFactory 同时调用两个方法来创建出两个对象,在这里这两个对象就有很大的相关性,Client 需要同时创建出这两个对象。
从高层次来看,抽象工厂使用了组合,即 Cilent 组合了 AbstractFactory,而工厂方法模式使用了继承。

参与者
AbstractFactory
- 声明一个创建抽象产品对象的操作接口。
ConcreteFactory
- 实现创建具体产品对象的操作。
AbstractProduct
- 为一类产品对象声明一个接口。
ConcreteProduct
定义一个将被相应的具体工厂创建的产品对象。
实现 AbstractProduct 接口。
Client
- 仅适用由 AbstractFactory 和 AbstractProduct 类声明的接口。
适用性
在以下情况下可以使用 Abstract Factory 模式:
一个系统要独立于它的产品的创建、组合和表示时。
一个系统要由多个产品系列中的一个来配置时。
当你要强调一系列相关的产品对象的设计以便进行联合使用时。
当你提供一个产品类库,而只想显示它们的接口而不是实现时。
缺点
- 难以支持新种类的产品。支持新种类的产品就需要扩展 AbstractFactory
接口,这将引起所有子类的改变。
效果
它分离了具体的类。
它使得易于交换产品系列。
它有利于产品的一致性。
相关模式
Abstract Factory 经常用 Factory
Method
来实现。Abstract Factory 也可以用
Prototype 来实现。一个具体的工厂可以是一个
Singleton。
命名约定
使用命名约定是一个好习惯,例如,总是声明那些定义为抽象工厂的类为 XxxKit。
2 实现
1 | public class AbstractProductA { |
1 | public class AbstractProductB { |
1 | public class ProductA1 extends AbstractProductA { |
1 | public class ProductA2 extends AbstractProductA { |
1 | public class ProductB1 extends AbstractProductB { |
1 | public class ProductB2 extends AbstractProductB { |
1 | public abstract class AbstractFactory { |
1 | public class ConcreteFactory1 extends AbstractFactory { |
1 | public class ConcreteFactory2 extends AbstractFactory { |
1 | public class Client { |










