《大话设计模式》将于11月底由清华大学出版社出版
《大话设计模式》第29章-OOTV杯超级模式大赛—模式总结(一)
《大话设计模式》第29章-OOTV杯超级模式大赛—模式总结(二)
《大话设计模式》第29章-OOTV杯超级模式大赛—模式总结(三)
《大话设计模式》第29章-OOTV杯超级模式大赛—模式总结(四)
(接上一篇)
29.7 行为型模式二组比赛
“欢迎回到第一届OOTV杯超级设计模式大赛现场,下面是行为型模式二组,也就是最后一组的比赛,她们将穿C++旗袍出场。”
“首先出场的是18号选手,
18号选手 解释器(interpreter)
“19号选手是中介者小姐,她说她是用一个中介对象来封装一系列的对象交互。中介者使各对像不需要显式地相互引用,从而使其耦合松散,而且可以独立地改变它们之间的交互。[DP]”
19号选手 中介者(Mediator)
“20号小姐向我们走来,访问者小姐,她表示一个作用于某对象结构中的各元素的操作。它使你可以在不改变各元素的类的前提下定义作用于这些元素的新操作。[DP]”
20号选手 访问者(Visitor)
“21号小姐是策略,一个可爱的姑娘,她的意图是定义一系列的算法,把它们一个个封装起来,并且使它们可相互替换。本模式使得算法可独立于使用它的客户而变化。[DP]”
21号选手 策略(Strategy)
“22号选手,备忘录小姐,她说在不破坏封装性的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态。这样以后就可将该对象恢复到原先保存的状态。[DP]”
22号选手 备忘录(Memento)
“最后一名选手,23号,迭代器小姐,她说,提供一种方法顺序访问一个聚合对象中各个元素,而又不需暴露该对象的内部表示。[DP]”
23号选手 迭代器(Iterator)
Hibernate:“这组里我只认识策略小姐,看过她做过不少广告,迭代器好像也听说过。其他的MM太没名气了,我不看好她们。”
ADO.NET:“中介者也还算行吧,至少我是知道她的。不过这一组实力是不太强,估计策略拿第一没什么悬念了。”《大话设计模式》
“好的,各位小姐已展示完毕,下面有请评委提问。”主持人GOF说。
“请问
“中介者小姐,人家都说你是交际花,请问你广交朋友的目的是什么?”迪米特问道。
“交际花不敢当,但我的确喜欢交朋友。面向对象设计鼓励将行为分布到各个对象中,这种分布可能会导致对象间有许多连接。也就是说,有可能每一个对象都需要知道其他许多对象。对象间的大量相互连接使得一个对象似乎不太可能在没有其他对象的支持下工作,这对于应对变化是不利的,任何较大的改动都很困难[DP]。所以说朋友多既是好事情,其实也是坏事情。我提倡将集体行为封装一个单独的中介者对象来避免这个问题,中介者负责控制和协调一组对象间的交互。中介者充当一个中介以使组中的对象不再相互显式引用。这些对象仅知道中介者,从而减少了相互连接的数目[DP]。我作为中介者,广交朋友,就起到了在朋友间牵线搭桥的作用。可以为各位朋友们服务。这其实不也正是迪
现在轮到访问者了,她面无表情,不知是否很紧张。合成聚合复用问道:“访问者小姐,听说你对朋友要求很苛刻,要请到你帮忙是很难的事情,你喜欢交朋友吗?”
听到这个问题,访问者笑开了颜:“哪有这种事情,朋友要我帮忙,我都会尽力而为的。的确,我不太喜欢交很多朋友,一般找到好朋友了,就不喜欢再交往新的朋友了。我的理念是朋友在精不在多。但是我和朋友间的交往通常会是多方面的,一同聊天、逛街、旅游、唱歌、游泳,哪怕是我们不会的活动,我们也可以尝试一起去学习、去扩展我们的生活情趣。也就是说,访问者增加具体的Element是困难的,但增加依赖于复杂对象结构的构件的操作就变得容易。仅需增加一个新的访问者即可在一个对象结构上定义一个新的操作。”
“非常有意思的交友观。下面请策略小姐准备接受提问。”GOF说道。
“请问策略小姐,说说你对‘优先使用对象组合,而非类继承’的理解?”合成聚合复用问道。
策略小姐答得很流利,“继承提供了一种支持多种算法或行为的方法,我们可以直接生成一个类A的子类B、C、D,从而给它以不同的行为。但这样会将行为硬行编制到父类A当中,而将算法的实现与类A的实现混合起来,从而使得类A难以理解、难以维护和难以扩展,而且还不能动态地改变算法。仔细分析会发现,它们之间的唯一差别是它们所使用的算法或行为,将算法封装在独立的策略Strategy类中使得你可以独立于其类A改变它,使它易于切换、易于理解、易于扩展[DP]。这里显然使用对象组合要优于类继承。”
“策略小姐说得非常好,下面想请问一下备忘录小姐,在保存对象的内部状态时,为何需要考虑不破坏封装细节的前提?”单一职责问道。
“通常原对象A都有很多状态属性,保存对象的内部状态,其实也就是将这些状态属性的值可以记录到A对象外部的另一个对象B,但是,如果记录的过程是对外透明的,那就意味着保存过程耦合了对象状态细节。使用备忘录就不会出现这个问题,它可以避免暴露一些只应由对象A管理却又必须存储在对象A之外的信息。备忘录模式把可能很复杂的对象A的内部信息对其他对象屏蔽起来,从而保持了封装边界[DP]。”
“最后一位,迭代器小姐,说说迭代器模式对遍历对象的意义?”里氏代换问道。
“一个集合对象,它当中具体是些什么对象元素我并不知道,但不管如何,应该提供一种方法来让别人可以访问它的元素,而且可能要以不同的方式遍历这个集合。迭代器模式的关键思想是将对列表的访问和遍历从列表对象中分离出来并放入一个迭代器对象中,迭代器类定义了一个访问该列表元素的接口。迭代器对象负责跟踪当前的元素,并且知道哪些元素已经遍历过了[DP]。”《大话设计模式》
“下面有请六位评委评选出行为型二组比赛的第一名。”GOF说道。
“迭代器小姐2票、策略小姐4票。”GOF宣布。“晋级的是策略小姐。”
“Yeah!”策略小姐右手伸出食指和中指,打了“V”型手势,向台前晃了晃,然后收到头顶上方握紧拳头做下拉状。
“哈,策略小姐高兴起来真像个孩子,说说感受吧。”GOF对策略的反应也很开心,微笑着说。
“我要感谢OOTV,感谢六位评委,感谢咱爸咱妈,感谢所有支持我的朋友,我爱你们!”策略仿佛已经问鼎冠军一样说了一大堆感谢的话。
“各位观众,请加快给你喜爱的选手投票,广告过后,我们将关闭短信通道。宣布投票结果。”GOF宣布说。
听主持人一宣布,下面的Fans们又纷纷掏出手机开始最后一轮的疯狂短信。
Hibernate :“看来我们英雄所见完全相同。”
ADO.NET:“是呀,策略早就成名了,所以很习惯于这种大场合说些场面话,明星也是练出来的。”
Hibernate :“现在工厂方法、外观、观察者、策略晋级了,除了这几位,你猜短信的结果是谁?”
ADO.NET:“从感觉上来讲,组合、命令、适配器、迭代器都有机会。”
Hibernate :“就不会出黑马?比如抽象工厂、代理、模板方法、桥接等?不过这次确实难料了。”《大话设计模式》
声明一下,本29章,可以代表本书的幽默风格,却不能代表本书的讲解技术的方式。正因为这一章的最与众不同,我本想让朋友们可以从全新的视角去看待23个设计模式,回顾一下它们的相同与不同。可惜是剑就有双刃,我忽略了有很多朋友是不了解《小菜编程成长记》的,以为本书全是这种娱乐化的书写,因此得出这样的文字不能得到收获结论。事实并非如此,否则出版社也不会出版本书,而只会让它上IT娱乐杂志了。在将此章结束后,我会帖出讲解设计模式的样章,希望您继续关注。