您的位置:
首页
->
编程文档
->
软件工程
-> 《设计模式Design Pattern》读书笔记之二
软件工程
本类阅读TOP10
·
PHP4 + MYSQL + APACHE 在 WIN 系统下的安装、配置
·
Linux 入门常用命令(1)
·
Linux 入门常用命令(2)
·
使用 DCPROMO/FORCEREMOVAL 命令强制将 Active Directory 域控制器降级
·
DirectShow学习(八): CBaseRender类及相应Pin类的源代码分析
·
基于ICE方式SIP信令穿透Symmetric NAT技术研究
·
Windows 2003网络负载均衡的实现
·
一网打尽Win十四种系统故障解决方法
·
数百种 Windows 软件的免费替代品列表
·
收藏---行百里半九十
→
分类导航
VC语言
Delphi
VB语言
ASP
Perl
Java
Script
数据库
其他语言
游戏开发
文件格式
网站制作
软件工程
.NET开发
《设计模式Design Pattern》读书笔记之二
作者
:未知
来源
:月光软件站
加入时间
:2005-2-28 月光软件站
《设计模式Design Pattern》读书笔记之二
Abstract Factory模式
别名
Kit
结构
优点
1, 通过仅仅将接口提供给Client,使得Client与接口的实现隔离开来,从而Client无需考虑接口的具体实现。
2, 使得更换产品系列(Product Families)更加便捷,仅仅需要替换一个ConcreteFactory的变量就可以了。
3, 通过Factory这个概念,保证了一个系列(Family)中的各个产品(Product)的一致性。就是说,一个系列中的某个产品只能在属于它的系列中生产和使用,其他的系列不能生产和使用它。
缺点
1, 新增加一类Product不是很容易。
A) 通常,对于每一类Product,AbstractFactory都需要通过为它分配一个操作(operation)来创建它;如果新增加一类Product,AbstractFactory就需要增加一个操作(operation),这样由于接口发生了改变,就会影响到所有跟AbstractFactory相关的类(需要重新编译)。
B) 一个解决的办法是,所有的Product公用一个操作(比如:Make)来创建它们。通过传入一个参数来决定创建什么类型的Product(但是,增加一个参数的类别不是也会影响到所有跟AbstractFactory相关的类吗?不过,可以有简单的技术手段来解决。)
前提是: 这种解决方法需要各个Product都是派生自同一个基类(作为返回类型);或者返回类型为VOID*,然后Client可以安全地强制转换(coerce)成所需的类型。即使各个Product都是派生自同一个基类,还是有一个继承的问题,当Client获得基类的指针后,需要使用派生类的成员的时候,需要downcast(即C++中的dynamic-cast),虽然类型的安全性可以保证,但downcast有失败的可能性,因此仍然有安全性的问题。
C) 由此可见,需要在灵活性和安全性之间做一个取舍。
2, 书中没有谈到的一点是,AbstractFactory为各种Product的生产而提供的操作接口,需要保证能满足所有ConcreteFactory的要求。比如,CreateProductA()的参数个数以及类型对ConcreteFactoryA是满足了要求的,但如果对ConcreteFactoryB而言不满足的话就不行了吧。
扩展
1, AbstractFactory不设计成纯虚类的时候,可以同时担当通用的ConcreteFactory的功能。
2, 一个程序通常只需要一个ConcreteFactory对象,这时候,可以使用Singleton模式
3, 如上述所示,通常来说,是使用Factory Method模式来生产Product,优点是比较简单。但,对每一系列(Family)都需要派生一个ConcreteFactory类来实现,如果各个系列之间的区别并不是很大,就会有很大的浪费;这时候,可以采用Prototype模式来解决,可以避免为对每一系列(Family)都需要派生一个ConcreteFactory类的问题。
参考资料:
《Design Pattern》 Gang-Of-4 1997
中秋快乐!
Jady Leung
2004年9月28日
相关文章
:
相关软件
: