《设计模式Design Pattern》读书笔记之二

原创 2004年09月28日 18:41:00
            《设计模式Design Pattern》读书笔记之二
            Abstract Factory模式

别名
Kit

结构


abfac108.gif


优点

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



中秋快乐!Pizza.gif

Jady Leung  coffee.gif
2004年9月28日


什么是设计模式?(Design pattern)--和生活结合更好理解

什么是设计模式 一套被反复使用、多数人知晓的、经过分类编目的、代码 设计经验 的总结;使用设计模式是为了 可重用 代码、让代码 更容易 被他人理解、保证代码 可靠性;设计模式使代码编制  真正工程...
  • guo13313
  • guo13313
  • 2017年04月09日 07:50
  • 949

设计模式 - 迭代器模式(iterator pattern) 详解

迭代器模式(iterator pattern) 详解本文地址: http://blog.csdn.net/caroline_wendy迭代器模式(iterator pattern) : 提供一种方法顺...
  • u012515223
  • u012515223
  • 2014年06月27日 14:03
  • 1912

Design Pattern Explained 读书笔记四——Adapter

What?Convert the interface of a class into another interface that the clients expect. Adapter lets ...
  • lemon89
  • lemon89
  • 2015年07月28日 23:50
  • 511

设计模式 - Design Patterns

设计模式四人组 GoF(“四人帮”,又称Gang of Four,即Erich Gamma、Richard Helm、Ralph Johnson和John Vlissides四人)1. 起源Go...
  • u010297957
  • u010297957
  • 2016年03月29日 23:20
  • 1051

设计模式之---单例模式(Singleton Design Pattern)

场景 对象只要利用自己的属性完成了自己的任务.那该对象就是承担了责任。 除了维持了自身的一致性,该对象无需承担其他任何责任。 如果该对象还承担着其他责任,而其他对象又依赖于该特定对象所承担的贵任...
  • u010878994
  • u010878994
  • 2016年04月26日 01:19
  • 585

EJB 设计模式概述

一. 设计模式重要性采用EJB技术的J2EE项目中,EJB架构的设计好坏将直接影响系统的性能、可扩展性、可维护性、组件可重用性及开发效率。项目越复杂,项目队伍越庞大则越能体现良好设计的重要性。  二....
  • happyxyzw
  • happyxyzw
  • 2007年07月17日 14:33
  • 1374

设计模式 - 策略模式(Strategy Pattern) 详解

策略模式(Strategy Pattern) 详解 本文地址: http://blog.csdn.net/caroline_wendy/article/details/26577879 本文版...
  • u012515223
  • u012515223
  • 2014年05月22日 13:31
  • 2918

设计模式总结之Visitor Pattern(访问者模式)

表示一个作用于某对象结构中的各元素的操作。它使你可以在不改变各元素的类的前提下定义作用于这些元素的新操作。...
  • cooldragon
  • cooldragon
  • 2016年08月12日 12:10
  • 4164

c++ 泛型 编程 之 Functor 设计模式

完整代码见:  http://download.csdn.net/detail/zhuyingqingfen/8457091#ifndef FUNCTOR_H_ #define FUNCTOR_H_ ...
  • zhuyingqingfen
  • zhuyingqingfen
  • 2015年02月25日 17:32
  • 1375

《设计模式Design Pattern》读书笔记之二十一

《设计模式Design Pattern》读书笔记之二十一Visitor模式结构 目的当一个对象(node)结构相对固定的时候,通过创建一个一个visitor对象来对这个结构中的所有node进行访问;而...
  • Jadyleung
  • Jadyleung
  • 2005年04月04日 14:45
  • 1097
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:《设计模式Design Pattern》读书笔记之二
举报原因:
原因补充:

(最多只允许输入30个字)