目录
本节关于FACTORY METHOD 工厂方法 —— 对象创建模式
1. 意图
定义一个用于创建对象的接口,让子类决定实例化哪一个类。Factory Method使一个类的实例化延迟到其子类。
2. 别名
虚构造器(Virtual Constructor)
3. 动机
框架使用抽象类定义和维护对象之间的关系。这些对象的创建通常也由框架负责。
问题:某应用框架向用户显示多个文档。两个主要的抽象是抽象类Application和Document,客户通过其子类来做与具体应用相关的实现。但Application只知道一个新文档何时被创建,而不知道哪一种Document将被创建。这使得:框架必须实例化类,但它只知道不能被实例化的类。
解决方法如下:
封装哪一个Document子类将被创建的信息并将这些信息从该框架中分离出来。Application的子类重定义Application的抽象操作CreateDocument以返回适合的Document子类对象。一旦一个Application子类实例化后,它就可以实例化与应用相关的文档,而无需知道这些文档的类。
4. 适用性
- 当一个类不知道它所必须创建的对象的类
- 当一个类希望由其子类来指定它所创建的对象
- 当类将创建对象的职责委托给多个帮助子类中的某一个,并且希望将哪一个帮助子类是代理者这一信息局部化的时候
5. 结构
6. 参与者
- Product(Document)
- 定义工厂方法所创建的对象的接口
- ConcreteProduct(MyDocument)
- 实现Product接口
- Creator(Application)
- 声明工厂方法,该方法返回一个Product类型的对象。Creator也可以定义一个工厂方法的缺省实现,它返回一个缺省的ConcreteProduct对象
- 可以调用工厂方法以创建一个Product对象
- ConcreteCreate(MyApplication)
- 重定义工厂方法以返回一个ConcreteProduct对象
7. 协作
- Creator依赖于其子类来定义工厂方法,所以它返回一个适当的ConcreteProduct实例
8. 效果
- 为子类提供挂钩(hook)
- 连接平行的类层次
9. 实现
Factory Method主要有两种不同的情况
- Create
- 参数化工厂方法