2018-05-02 《设计模式:可复用面向对象软件的基础》- 引言

作者:GoF(Gang of Four)四人组
四位作者均是国际公认的面向对象软件领域的专家。
Erich Gamma博士是瑞士苏黎士国际面向对象技术软件中心的技术主管。
Richard Helm博士是澳大利亚悉尼IBM顾问集团公司面向对象技术公司的成员。
Ralph Johnson博士是Urbana-Champaign伊利诺大学计算机科学系成员。
John Vlissides博士是位于纽约Hawthorne的IBN托马斯J.沃森研究中心的研究人员。

译者:李英军 马晓星 蔡敏 刘建中 等
审校:吕建

上一篇文章《程序员的职业素养 - The Clean Coder》提到了《设计模式》,接下来的几篇文章将简单记录这本书的内容

第一章 引言

本书的目的就是将面向对象软件的设计经验作为设计模式记录下来。

1.1 什么是设计模式

一个设计模式有四个基本要素:

  1. 模式名称(pattern name)
  2. 问题(problem)
  3. 解决方案(solution)
  4. 效果(consequences)

1.2 Smalltalk MVC中的设计模式

MVC(Model/View/Controller)三元组已经是家喻户晓了,这里拿它举例的目的是:MVC本身就使用了多种设计模式,同时通过进一步的优化,可以从MVC模式引申出更多的设计模式。例如:

  1. 将对象分离,使得一个对象的改变能影响另一些个对象,而不需要知道被影响的对象的细节 - Observer模式
  2. 视图可以嵌套,例如按钮控制面板可以复用按钮,MVC用View类的子类CompositeView类来支持嵌套视图 - Composite模式
  3. View-Controller的关系是 Strategy模式 的一个例子。一个策略是一个表述算法的对象。当你想静态或动态地替换一个算法,或者你有许多算法,或算法里包含你想封装的复杂数据结构,这时策略模式是很有用处的。
这里的意思是,设计模式在实际使用中,往往是交织在一起的,并不是各自独立的。
了解设计模式,但也不必拘泥于现有的模式,根据需求灵活组合即可。

1.3 描述设计模式

模式名和分类,意图,别名,动机,适用性,
结构,参与者,协作,效果,实现,代码示例,
已知应用,相关模式

1.4 设计模式的编目

总共有23个设计模式,名称及关系如下图


image.png

1.5 组织编目

即分类:

创建型 结构型 行为型
Factory Method Adapter(类) Interpreter,Template Method
对象 Abstract Factory; Builder; Prototype; Singleton Adapter; Bridge; Composite; Decorator; Facade; Flyweight; Proxy Chain of Responsibility; Command; Iterator; Mediator; Memento; Observer; State; Strategy; Visitor

这样分类的原则是:

  1. 目的准则:即用来完成什么样的工作的
  2. 范围准则:即指定模式是用于类还是用于对象的

也就是如上面的表格那样,从两个纬度对设计模式进行分类。

1.6 设计模式是怎样解决设计问题的

  1. 寻找合适的对象
  2. 决定对象的粒度
  3. 指定对象接口
    对象操作所定义的所有操作型构的集合被称为该对象的接口(interface)。实现了某个接口(Window)定义的全部操作请求的对象,就可以被称为具有 “Window” 类型。

A接口包含了B接口,则A是B的子类型(subtype),B是A的超类型(supertype)。

  1. 描述对象的实现
    对象通过实例化类来创建,此对象被称为该类的实例。
    子类继承父类,即包含了父类定义的所有数据和操作。
    抽象类的主要目的是为它的子类定义公共接口。不能实例化。抽象类中定义却没有实现的操作被称为抽象操作(abstract operation)。非抽象类称为具体类。
    混入类(mixin class)是给其他类提供可选择的接口或功能的类,也不能实例化。

第一原则:对接口编程,而不是针对实现编程
不将变量声明为某个特定的具体类的实例对象,而是让它遵从抽象类所定义的接口。

  1. 运用复用机制
  • 继承和组合的比较

第二原则:优先使用对象组合,而不是类继承。

  • 委托(delegation)是一种组合方法,它是组合具有与继承同样的复用能力。

  • 继承和参数化类型的比较

  1. 关联运行时刻和编译时刻的结构

  2. 设计应支持变化
    应用程序,工具箱,框架(一个比一个难)

  • 设计模式比框架更抽象
  • 设计模式是比框架更小的体系结构元素
  • 框架比设计模式更加特例化

1.7 怎样选择设计模式

1.8 怎样使用设计模式

先熟悉了解各个设计模式,再结合实际问题,就知道如何选择和使用设计模式了。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 195,898评论 5 462
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,401评论 2 373
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 143,058评论 0 325
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,539评论 1 267
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,382评论 5 358
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,319评论 1 273
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,706评论 3 386
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,370评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,664评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,715评论 2 312
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,476评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,326评论 3 313
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,730评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,003评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,275评论 1 251
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,683评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,877评论 2 335

推荐阅读更多精彩内容

  • 设计模式汇总 一、基础知识 1. 设计模式概述 定义:设计模式(Design Pattern)是一套被反复使用、多...
    MinoyJet阅读 3,878评论 1 15
  • 参考资料:菜鸟教程之设计模式 设计模式概述 设计模式(Design pattern)代表了最佳的实践,通常被有经验...
    Steven1997阅读 1,160评论 1 12
  • 没有结果的事情,并不一定是没有意义的。就拿我们这次参加挑战杯来说,我们前前后后忙了这么久,到头来发现我们所有的想法...
    逗逗逗酱阅读 652评论 0 51
  • 一颗流星划过天边, 那瞬间, 我仿若看到三年前你眼中的那一缕留恋。 山青水远, 路遥遥, 我追你的感觉像是爱上了新...
    伦小让阅读 271评论 4 3
  • 在这两部分的系列中,第一个部分的将解释 GCD 是做什么的,并从许多基本的 GCD 函数中找出几个来展示。在第二部...
    透支未来阅读 328评论 0 1