设计模式的学习就要结束了,这么些天,一直徜徉在大鸟和小菜的故事世界之中。那一段段经典的对话,那一个个有趣而又充满知识的经历,真的让自己受益匪浅。
除此之外,那场OOTV杯超级模式大赛,真的很精彩。那么,就让我们随着比赛的脚步,再一次充当观众,一起去回味,再次领略各种模式的魅力所在。
主持人——GOF,首先出现在台前给大家问好。可能有人就会问了,为什么主持人会是她呢?其实,学习了设计模式的同学都知道,GOF来头可不小。下面就让我先给大家对GOF做一个简单介绍吧。
GOF,全称Gang ofFour,中文名称为四人组。《Design Patterns: Elements of Reusable Object-Oriented Software》(即后述《设计模式》一书),由
Erich Gamma、Richard Helm、Ralph Johnson 和 John Vlissides 合著(Addison-Wesley,1995)。这几位作者常被称为"四人组(Gang of Four)",而这本书也就被称为"四人组(或 GoF)"书。
接下来,GOF为我们介绍了第一位到场的嘉宾,OOTV的创始人——面向对象先生。也许,我们没有和他有过亲身接触,但实际上,他的思想早已闻名于我们身边。至今,他仍是我们最为敬佩的人。在他的身上,不管是封装、继承还是多态,我们都需要好好去学习。
下面,GOF为我们介绍的是本场比赛的六大评审。只要是敲起了键盘,编起了程序,我们都需要问问评审的意见,看看究竟合不合他们的口味呗。看,有他们六个在台上坐阵,场面瞬间严肃了不少。不过,我们还是需要来一一介绍他们一下。
【单一职责先生】他给人的感觉可能比较难接触,所以他的朋友也比较少。他奉行的原则是:就一个类而言,应该仅有一个引起它变化的原因。
【开放封闭先生】他就像是我们常说的包公吧,铁面无私。他奉行的原则是:软件实体(类、模块、函数等等)应该可以扩展,但是不可修改。
【依赖倒转先生】他这个人比较专一吧,死心塌地。他奉行的原则是:高层和低层模块都应该依赖抽象,细节也应该依赖抽象。
【里氏代换女士】她很无私奉献的,自己有的一切都会毫不保留的传给孩子们。她奉行的原则是:子类型必须能够替换掉它们的父类型。
【合成聚合复用女士】她总是给予我们谆谆教导,告诉我们什么可以做,什么尽量不要做。她奉行的原则是:尽量使用合成聚合,尽量不要使用类继承。
【迪米特先生】他总是想着让我们省点事,自己多做点。他奉行的原则是:如果两个类不必彼此直接通信,那么这两个类就不应当发生直接的相互作用。如果其中一个类需要调用另一个类的某一个方法的话,可以通过第三者转发这个调用。
好了,随着GOF宣布完比赛规则:“本次大赛根据模式的特点,设置了三个类别,分别是创建型模式、结构型模式和行为型模式。……”比赛就开始了。首先上场的是第一组创建型模式的五名选手。她们分别是:
下面把舞台交给她们几个,一起来欣赏她们的SHOW TIME。
【抽象工厂小姐】有她在,想访问数据库中的任何表都变得轻松了。她的口号是提供一个创建一系列或相关依赖对象的接口,而无需指定它们的具体的类。
【建造者小姐】有了她,我们可以构建出各种不同的小人了。她的口号是将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示。
【工厂方法小姐】访问数据,虽然她不及她姐姐那样,但她还是给我们带来了很多方便的。她声称定义一个用于创建对象的接口,让子类决定实例化哪一个类,工厂模式使一个类的实例化延迟到其子类。
【原型小姐】你还在为简历而苦恼吗?原型,她就可以帮我们搞定的。她意图是用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象。
【单例小姐】数量上只有一个,但这就足够了,何必要浪费呢,单例,她一直看着我们呢。工具箱一个就够了。她提倡简捷就是美,保证一个类仅有一个实例,并提供一个访问它的全局访问点。
好了,我们对五位选手也有了进一步的了解。从她们各自的口号来看,不难发现,其实她们之所以被安排在第一轮创建型模式中还是有原因的,简单来说,她们都是用各自的方法去实现创建自己实例。特别地,工厂方法和抽象工厂两姐妹真的很相似,只是两者的抽象程度不同。
第二组上场的是结构型模式的七名选手,
看看她们又将给我们展示什么吧。
【适配器小姐】还在担心不能和外国人交流吗?姚明都是派适配器出场的,你不用,就OUT了。她的口号是将一个类的接口转换成客户希望的另一个接口。适配器模式使得原本由于接口不兼容而不能一起工作的那些类可以一起工作。
【桥接小姐】羡慕别人苹果手机上的软件?不着急,找桥接,她让你手机上也同样拥有。她所提倡的是将抽象部分与它的实现部分分离,使它们都可以独立地变化。
【组合小姐】一个公司,最重要的是资源共享,害怕自己被落下吗?有组合在,你永远不会被抛弃的。她的口号是将对象组合成树形结构以表示‘部分-整体’的层次结构,组合模式使得用户对单个对象和组合对象的使用具有一致性。
【装饰小姐】要去见对象了,该怎么打扮一番呢?请装饰来帮忙吧,只要你想要的,她就可以帮你实现。她的意图是动态地给一个对象添加一些额外的职责。就增加功能来说,她比生成子类更加灵活。
【外观小姐】投资有风险,处处需谨慎啊,想要回家睡觉也可挣钱,还是找外观帮忙吧,她上面有人。她说为子系统中的一组接口提供一个一致的界面,外观模式定义了一个高层接口,这个接口使得这一子系统更加容易使用。
【享元小姐】会做网站,大家都来找。可是效率低,这不事倍功半了吗。问问享元吧,她会帮我们解决的。她的参赛宣言为运用共享技术有效地支持大量细粒度的对象。
【代理小姐】想送喜欢的人一个礼物,又不好意思。那就找代理吧,别人不会揭穿你的。她声称为其他对象提供一种代理以控制对这个对象的访问。
很明显,这组选手和创建型选手表现得侧重点就不一样了。从她们的口号中,我们可以更明显的看出她们都是在强调类与类、对象与对象之间的关系,使出自己的浑身解数,一方面减轻自己负担,另一方面也是为了可以给大家带去更方便周到的服务。
最后还剩下行为型的两组选手了,共11位,
下面有请她们一一登场吧。
【观察者小姐】被老板抓着上班看股票球赛了,那你肯定和观察者关系不怎么好吧。她的口号是定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都得到通知并自动更新。
【模板方法小姐】考试成绩低,为什么呢?原来题目都抄错了,能不错吗。下次还是请模板方法帮帮忙吧,一定高分飞过。她提倡定义一个操作的算法骨架,而将一些步骤延迟到子类中,模板方法使得子类可以不改变一个算法的结构即可重新定义该算法的某些特定步骤。
【命令小姐】去饭店吃饭感觉真好,那个叫命令的服务员服务真周到,随叫随到,也不用担心她多收费。她觉得应该将一个请求封装为一个对象,从而使你可用不同的请求对客户进行参数化;可以对请求排队或记录请求日志,以及支持可撤销的操作。
【状态小姐】每天都要工作,谁有本事时时刻刻都精神抖擞。还是该吃饭吃饭,该睡觉睡觉,该工作工作,该下班下班呗。她说一个对象在其内部状态改变时改变它的行为,让对象看起来似乎修改了它的类。
【职责链小姐】物价上涨,想加薪啊,给谁说啊。这个不用担心,告诉职责链就行,她会管理好一切的,你说出来就行。她一直认为使多个对象都有机会处理请求,从而避免请求的发送者和接收者之间的耦合关系。将这些对象连成一条链,并沿着这条链传递该请求,直到有一个对象处理它为止。
【解释器小姐】老板找你谈话,忐忑吧,他究竟是想夸我呢还是炒我呢,真是不懂啊。还是问问解释器吧。她声称给定一个语言,定义它的文法的一种表示,并定义一个解释器,这个解释器使用该表示来解释语言中的句子。
【中介者小姐】现在的生活这么和平安定,全要靠中介者找来安理会帮忙啊。要是他走了,那第三次世界大战还不得爆发了啊。她说她是用一个中介对象来封装一系列的对象交互。中介者使各对象不需要显式地相互引用,从而使其耦合松散,而且可以独立地改变它们之间的交互。
【访问者小姐】你成功了,失败了,亦或是恋爱了,结婚了,想过别人的感受吗。问问访问者吧,她都可以告诉你。她表示一个作用于某对象结构中的各元素的操作。它使你可以在不改变各元素的类的前提下定义作用于这些元素的新操作。
【策略小姐】商场时时促销,我该怎么买才划算呢。问问策略吧,让她帮我们算算账。她的意图是定义一系列的算法,把它们一个个封装起来,并且使它们可相互替换。本模式使得算法可独立于使用它的客户而变化。
【备忘录小姐】消消乐好不容易打到130关了,一死机,全都没了。怪谁啊,还是怪自己呗,谁让你打游戏不找备忘录一起的。她说在不破坏封装性的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态。这样以后就可将该对象恢复到原先保存的状态。
【迭代器小姐】公交车那个拥挤啊,直接混上车得了,谁还买票啊。休想,上车容易下车难,不买票谁都别走,迭代器在门口等着你呢。她说提供一种方法顺序访问一个聚合对象中各个元素,而又不需暴露该对象的内部表示。
这么看来,她们几个都可以算得上是我们的生活小助手。她们为我们提供各种方法,以备我们不时之需啊。
这样的比赛,看多少次都不会觉得烦,不仅是大饱眼福,而且也涨了不少见识。
尾言:
这篇博客主要是又把设计模式总体上过一遍,对于每个模式细节上的东西都没有作详细说明,自己感觉细节的东西还是需要在一遍遍学习中逐步积累,其中有对某些模式做了专门的总结写成博客。而学习前后,宏观的把握两遍还是有必要去做的。