标签:
图-抽象工厂模式结构图
抽象工厂模式包含以下角色:
AbstractProduct : 声明一个接口,这个接口中包含产品对象类型。
ConcreteProduct : 定义一个产品对象,这个产品对象是由相关的具体工厂创建的。
AbstractFactory : 声明一个接口,这个接口中包含创建抽象产品对象的方法。
ConcreteFactory : 实现创建具体产品对象的方法。
Client : 只使用 AbstractFactory 和 AbstractProduct 声明的接口。
运行结果
一个系统要独立于它的产品的创建、组合和表示时。
一个系统要由多个产品系列中的一个来配置时。
当你要强调一系列相关的产品对象的设计以便进行联合使用时。
当你提供一个产品类库,而只想显示它们的接口而不是实现时。
(1)抽象工厂模式隔离了具体类的生成,用户并不需要知道什么被创建。由于这种隔离,更换一个具体工厂变得相对容易。所有的具体工厂都实现了抽象工厂中定义的那些公共接口,因此只需要改变具体工厂的实例,就可以在某种程度上改变整个软件系统的行为。另外,应用抽象工厂模式可以实现高内聚低耦合的设计目的,因此抽象工厂模式得到了广泛的应用。
(2)当一个产品族中的多个对象被设计成一起工作时,它能够保证客户端始终只使用同一个产品族中的对象。这对一些需要根据当前环境来决定其行为的软件系统来说,是一种非常实用的设计模式。
(3)增加新的具体工厂和产品族很方便,无须修改已有系统,符合“开放封闭原则”。
在添加新的产品对象时,难以扩展抽象工厂来生产新种类的产品,这是因为在抽象工厂角色中规定了所有可能被创建的产品集合,要支持新种类的产品就意味着要对该接口进行扩展,而这将涉及到对抽象工厂角色及其所有子类的修改,显然会带来较大的不便。
标签:
原文地址:http://www.cnblogs.com/jingmoxukong/p/4211446.html