创建型-简单工厂-工厂方法-抽象工厂
# 简单工厂
# 总览
该设计模式意图在创建一个对象时不向客户暴露内部细节,并提供一个创建对象的通用接口。
简单工厂不是设计模式,更像是一种编程习惯。它把实例化的操作单独放到一个类中,这个类就成为简单工厂类,让简单工厂类来决定应该用哪个具体子类来实例化。
# 工厂方法
# 总览
该设计模式定义了一个创建对象的接口,但由子类决定要实例化哪个类。工厂方法把实例化操作推迟到子类。
在简单工厂中,创建对象的是另一个类,而在工厂方法中,是由子类来创建对象。
下图中,Factory 有一个 doSomething() 方法,这个方法需要用到一个产品对象,这个产品对象由 factoryMethod() 方法创建。该方法是抽象的,需要由子类去实现(但是在简单工厂模式中,Factory并没有子类,创建ConcreteProduct由自身完成)。
# 抽象工厂
# 总览
抽象工厂模式提供一个接口,用于创建 相关的对象家族 。
抽象工厂模式创建的是对象家族,也就是很多类对象而不是一类对象,并且这些对象是相关的,也就是说必须一起创建出来。而工厂方法模式只是用于创建一类对象,这和抽象工厂模式有很大不同。
抽象工厂模式用到了工厂方法模式来创建单一对象,AbstractFactory 中的 createProductA() 和 createProductB() 方法都是让子类来实现,这两个方法单独来看就是在创建一个对象,这符合工厂方法模式的定义。
至于创建对象的家族这一概念是在 Client 体现,Client 要通过 AbstractFactory 同时调用两个方法来创建出两个对象,在这里这两个对象就有很大的相关性,Client 需要同时创建出这两个对象。
从高层次来看,抽象工厂使用了组合,即 Cilent 组合了 AbstractFactory,而工厂方法模式使用了继承。