軟件工程的23種設(shè)計(jì)模式的UML類圖_第1頁
軟件工程的23種設(shè)計(jì)模式的UML類圖_第2頁
軟件工程的23種設(shè)計(jì)模式的UML類圖_第3頁
軟件工程的23種設(shè)計(jì)模式的UML類圖_第4頁
軟件工程的23種設(shè)計(jì)模式的UML類圖_第5頁
已閱讀5頁,還剩12頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

1、二 十三種設(shè)計(jì)模式0 引言談到設(shè)計(jì)模式,絕對應(yīng)該一起來說說重構(gòu)。重構(gòu)給我們帶來了什么?除了作為對遺留代碼的改進(jìn)的方法,另一 大意義在于,可以讓我們在寫程序的時(shí)候可以不需事先考慮太多的代碼組織問題,當(dāng)然這其中也包括了應(yīng)用模式的問題。盡管大多數(shù)開發(fā)者都已經(jīng)養(yǎng)成了寫代碼前先 從設(shè)計(jì)開始的習(xí)慣,但是,這種程度的設(shè)計(jì),涉及到到大局、到總體架構(gòu)、到主要的模塊劃分我覺得就夠了。換句話說,這時(shí)就能寫代碼了。這就得益于重構(gòu)的思想 了。如果沒有重構(gòu)的思想,有希望獲得非常高質(zhì)量的代碼,我們就不得不在開始寫代碼前考慮更多其實(shí)并非非常穩(wěn)定的代碼組織及設(shè)計(jì)模式的應(yīng)用問題,那開發(fā)效率 當(dāng)然就大打折扣了。在重構(gòu)和設(shè)計(jì)模式的合

2、理應(yīng)用之下,我們可以相對較早的開始寫代碼,并在功能盡早實(shí)現(xiàn)的同時(shí),不斷地通過重構(gòu)和模式來改善我們的代碼質(zhì) 量。所以,下面的章節(jié)中,在談模式的同時(shí),我也會談?wù)勱P(guān)于常用的這些模式的重構(gòu)成本的理解。重構(gòu)成本越高意味著,在遇到類似的問題情形的時(shí)候,我們更應(yīng)該 提前考慮應(yīng)用對應(yīng)的設(shè)計(jì)模式,而重構(gòu)成本比較低則說明,類似的情形下,完全可以先怎么方便,怎么快怎么寫,哪怕代碼不是很優(yōu)雅也沒關(guān)系,回頭再重構(gòu)也很容 易。1 創(chuàng)建型1.1FactoryMethod思想:Factory Method的主要思想是使一個(gè)類的實(shí)例化延遲到其子類。場景:典 型的應(yīng)用場景如:在某個(gè)系統(tǒng)開發(fā)的較早階段,有某些類的實(shí)例化過程,實(shí)例化

3、方式可能還不是很確定,或者實(shí)際實(shí)例化的對象(可能是需要對象的某個(gè)子類中的一 個(gè))不確定,或者比較容易變化。此時(shí),如果直接將實(shí)例化過程寫在某個(gè)函數(shù)中,那么一般就是if-else或select-case代 碼。如果,候選項(xiàng)的數(shù)目較少、類型基本確定,那么這樣的if-else還是可以接受的,一旦情形變 得復(fù)雜、不確定性增加,更甚至包含這個(gè)構(gòu)造過程的函數(shù)所在的類包含幾個(gè)甚至更多類似的函數(shù)時(shí),這樣的if-else代 碼就會變得比較不那么容易維護(hù)了。此時(shí),應(yīng)用本模式,可以將這種復(fù)雜情形隔離開,即將這類不確定的對象的實(shí)例化過程延遲到子類。實(shí)現(xiàn):該模式的典型實(shí)現(xiàn)方法就是將調(diào)用類定義為一個(gè)虛類,在調(diào)用類定義一個(gè)專

4、門用于構(gòu)造不確定的對象實(shí)例的虛函數(shù),再將實(shí)際的對象實(shí)例化代碼 留到調(diào)用類的子類來實(shí)現(xiàn)。如果,被構(gòu)造的對象比較復(fù)雜的話,同時(shí)可以將這個(gè)對象定義為可以繼承、甚至虛類,再在不同的調(diào)用類的子類中按需返回被構(gòu)造類的子 類。重構(gòu)成本:低。該模式的重構(gòu)成本實(shí)際上還與調(diào)用類自己的實(shí)例化方式相關(guān)。如果調(diào)用類是通過Factory方 式(此處“Factory方式”泛指對象的實(shí)例化通過Factory Method或Abstract Factory這樣的相對獨(dú)立出來的 方式構(gòu)造)構(gòu)造的,那么,重構(gòu)成本相對就會更低。否則,重構(gòu)時(shí)可能除了增加調(diào)用類的子類,還要將所有實(shí)例化調(diào)用類的地方,修改為以新增的子類代替??赡苓@ 樣的子

5、類還不止一個(gè),那就可以考慮迭代應(yīng)用模式來改善調(diào)用類的實(shí)例化代碼。1.2AbstractFactory思想:不直接通過對象的具體實(shí)現(xiàn)類,而是通過使用專門的類來負(fù)責(zé)一組相關(guān)聯(lián)的對象的創(chuàng)建。場景:最典型的應(yīng)用場景是:您只想暴露對象的接口而不想暴露具體的實(shí)現(xiàn)類,但是又想提供實(shí)例化對象的接口給用戶;或者,您希望所有的對象能夠 集中在一個(gè)或一組類(通常稱作工廠類)來創(chuàng)建,從而可以更方便的對對象的實(shí)例化過程進(jìn)行動態(tài)配置(此時(shí)只需要修改工廠類的代碼或配置)。實(shí)現(xiàn):該模式的實(shí)現(xiàn)是比較清晰簡單的,如上圖,就是定義創(chuàng)建和返回各種類對象實(shí)例的工廠類。在最復(fù)雜而靈活的情形,無論工廠類本身還是被創(chuàng)建 的對象類都可能需要有

6、一個(gè)繼承體系。簡單情形其實(shí)可以只是一個(gè)工廠類和需要被創(chuàng)建的對象類。不一定非要像上圖中結(jié)構(gòu)那么完備(累贅)。重構(gòu)成本:中。如果一開始所有的對象都是直接創(chuàng)建,例如通過new實(shí)例化的, 而之后想重構(gòu)為Abstract Factory模式,那么,很自然的我們需要替換所有直接的new實(shí) 例化代碼為對工廠類對象創(chuàng)建方法的調(diào)用??紤]到像Resharper這樣的重構(gòu)工具的支持,找出對 某個(gè)方法或構(gòu)造函數(shù)的調(diào)用位置這樣的操作相對還是比較容易,重構(gòu)成本也不是非常高。同時(shí),重構(gòu)成本還和被創(chuàng)建對象的構(gòu)造函數(shù)的重載數(shù)量相關(guān)。您需要根據(jù)實(shí) 際情況考慮,是否工廠類要映射被創(chuàng)建對象的所有重載版本的構(gòu)造函數(shù)。1.3Builde

7、r思想:將一個(gè)類的創(chuàng)建過程和他的主體部分分離。場景:該模式的典型的應(yīng)用場景是:一個(gè)類的創(chuàng)建過程可能比較復(fù)雜,或者創(chuàng)建過程中的某些階段可能會容易變化;或者多個(gè)類的創(chuàng)建過程比較類似, 但是主體不同。實(shí)現(xiàn):在 以上提到的兩種場景中,我們就可以取出一個(gè)類的創(chuàng)建過程的代碼,定義一個(gè)專門的Builder類, 而在原來創(chuàng)建類對象實(shí)例的地方,將這個(gè)Builder類的實(shí)例作為參數(shù)傳入。還有第二個(gè)重點(diǎn),就是Builder類 可以將將整個(gè)創(chuàng)建過程分為幾個(gè)階段,每個(gè)階段不必在類中直接實(shí)現(xiàn),而可以通過繼承體系在子類中實(shí)現(xiàn),或者通過子類的方法過載來修改創(chuàng)建過程中的某個(gè)階段, 但是重用其他的階段。可以發(fā)現(xiàn),該模式將一個(gè)對象

8、的復(fù)雜創(chuàng)建過程重用到非常高的層次。這正是它的意義所在。重構(gòu)成本:低。該模式的重構(gòu)成本我覺得是非常低的,因?yàn)橐话銇碇v,創(chuàng)建過程的代碼本來也就應(yīng)該在原來的類的構(gòu)造函數(shù)中,把它Extract出 來就好了。如果發(fā)現(xiàn)多個(gè)類的創(chuàng)建過程有比較多的代碼重復(fù)或類似,那么就可以重用這些提取出來的Builder類 或者Builder類中的某些階段。1.4Prototype思想:克 隆一個(gè)已有的類的實(shí)例(大家相比都用過甚至寫過類的Clone實(shí)現(xiàn),應(yīng)該很容易理解了)。場景:應(yīng) 用Clone的場景應(yīng)該說非常多,理想情況下我當(dāng)然希望任何類都能Clone, 需要的時(shí)候就能Clone一份一模一樣的出來。實(shí)現(xiàn):這 里將的實(shí)現(xiàn)主要

9、之實(shí)現(xiàn)的表現(xiàn)形式,而不是如何用具體的語言來實(shí)現(xiàn)。因此,只要為需要Clone能力 的類定義一個(gè)Clone方法就行。當(dāng)然,一般,主流的程序語言框架都已經(jīng)定義了通用的Clone接 口(當(dāng)然也可以自己定義),繼承并實(shí)現(xiàn)該接口和方法就好。重構(gòu)成本:極低。不多解釋了吧。1.5 Singleton思想:保證一個(gè)類只有一個(gè)唯一的實(shí)例。場景:生活中有些對象就是只要一個(gè)就好了,我們的代碼中為什么要每次都為這樣的對象生成一個(gè)實(shí)例呢?實(shí)現(xiàn):最 簡單的實(shí)現(xiàn)方式就是使用一個(gè)static型的類實(shí)例,每次對該對象的創(chuàng)建請求都返回這個(gè)static的 唯一實(shí)例就行。重構(gòu)成本:極低。2 結(jié)構(gòu)型2.1Adapter思想:將一個(gè)類的接

10、口轉(zhuǎn)換成另外一個(gè)接口,使得原本由于接口不兼容而不能一起工作的那些類可以一起工作。場景:該 模式的應(yīng)用場景太多了,很多需要的功能模塊的接口和我們需要的不完全一致或者有多余或不足,但是需要和我們的系統(tǒng)協(xié)同工作,通過Adapter把 它包裝一下就能讓使它接口兼容了。實(shí)現(xiàn):定 義一個(gè)Adapter類,包含需要包裝的類,實(shí)現(xiàn)需要的其它接口,調(diào)用被包裝的類的方法來實(shí)現(xiàn)需要 的接口。重構(gòu)成本:低。2.2Bridge思想:將一個(gè)類的抽象定義和具體實(shí)現(xiàn)解耦。場景:該 模式的典型應(yīng)用場景是:一個(gè)類的抽象定義已經(jīng)確定,但是,其實(shí)現(xiàn)代碼甚至原理可能會不同。比如:我們最熟悉的圖形界面中的window的 實(shí)現(xiàn),無論在什么

11、操作系統(tǒng),什么平臺的機(jī)器上,一個(gè)window應(yīng)具有的抽象定義基本上是一致的, 但是,其實(shí)現(xiàn)代碼肯定會因?yàn)槠脚_不同,機(jī)器的代碼指令不同而不同。此時(shí),如果希望您寫的window類 能跨平臺,應(yīng)用Bridge模式就是一個(gè)好主意。實(shí)現(xiàn):該 模式的實(shí)現(xiàn)方法很簡單,就是除了定義類的抽象定義之外,將一個(gè)類的所有實(shí)現(xiàn)代碼獨(dú)立出一個(gè)實(shí)現(xiàn)類。這樣一來,無論是抽象定義還是實(shí)現(xiàn)類都能分別修改和重 用,但只要兩部分的交互接口不變,還是可以方便的互相組裝。當(dāng)然,實(shí)際上也沒有必要隔離出“所有實(shí)現(xiàn)代碼”,只需要隔離需要的部分就行了。因此,也可以 說,從代碼結(jié)構(gòu)來看,Builder模式是一種變種的Bridge模 式的。也經(jīng)常有

12、人將Bridge模式和接口相比較,如果隔離出所有的實(shí)現(xiàn),那么的確接口的方式也能 做到抽象定義和實(shí)現(xiàn)分離,但是,Bridge有其優(yōu)勢如下:一、究竟隔離多少代碼到Bridge類 中可以靈活確定,二、減少了總的類的數(shù)目,三、允許被隔離出來的Bridge類被其它的類直接共享 使用。重構(gòu)成本:中。將所有的(或很大部分)實(shí)現(xiàn)代碼分離開來總還是一件不大,但是,也不小的事。所以標(biāo)個(gè)“中”在這里。:)2.3Composite思想:將 對象組合成樹形結(jié)構(gòu)以表示“部分-整體”的層次結(jié)構(gòu),使得用戶對單個(gè)對象和組合對象的使用具有一致 性。場景:該 模式的應(yīng)用場景極其類似,比如像圖形系統(tǒng),如電路設(shè)計(jì)、UML建模系統(tǒng),或者

13、像web的 顯示元素等,都是那種需要整體和部分具有使用接口上的一定的一致性的需求的結(jié)構(gòu),實(shí)際上,我覺得這樣的系統(tǒng)如果不使用Composite模 式將會是慘不忍睹的。實(shí)現(xiàn):該模式的實(shí)現(xiàn)主要就是要表示整體或部分的所有類都繼承自同一的基類或接口,從而擁有使用接口上一定的一致性。重構(gòu)成本:高。2.4Decorator思想:為一個(gè)對象已有的子類添加一些額外的職責(zé)。場景:該模式的使用場景,主要是有的時(shí)候我們不愿意定義邏輯上新的子類,因?yàn)闆]有新的邏輯含義上的子類概念,而只是想為一個(gè)已存在的子類附加 一些職責(zé)。實(shí)現(xiàn):該 模式的實(shí)現(xiàn)主要就是定義一個(gè)物理上的新的子類,但是,它只是包含要附加職責(zé)的類,傳遞外部對相同

14、接口的調(diào)用,在這個(gè)傳遞調(diào)用的通道上附加額外的功能。突然 想到,Decorator模式是不是一定程度上也能代替DynamicProxy模 式,從而成為一種AOP實(shí)現(xiàn)的方案呢?重構(gòu)成本:低。定義一個(gè)Decorator和一個(gè)已有類的邏輯上的子類,物理 表現(xiàn)形式上都是一個(gè)子類,重構(gòu)也確實(shí)不是難事。2.5 Facade思想:為子系統(tǒng)中的一組接口提供一個(gè)一致的界面,這個(gè)接口使得這一子系統(tǒng)更加容易使用。場景:當(dāng) 你要為一個(gè)復(fù)雜子系統(tǒng)提供一個(gè)簡單接口時(shí)。子系統(tǒng)往往因?yàn)椴粩嘌莼兊迷絹碓綇?fù)雜。大多數(shù)模式使用時(shí)都會產(chǎn)生更多更小的類。這使得子系統(tǒng)更具可重用性, 也更容易對子系統(tǒng)進(jìn)行定制,但這也給那些不需要定制子系

15、統(tǒng)的用戶帶來一些使用上的困難。Facade可 以提供一個(gè)簡單的缺省視圖,這一視圖對大多數(shù)用戶來說已經(jīng)足夠,而那些需要更多的可定制性的用戶可以越過Facade層。 客戶程序與抽象類的實(shí)現(xiàn)部分之間存在著很大的依賴性。引入Facade將這個(gè)子系統(tǒng)與客戶以及其他 的子系統(tǒng)分離,可以提高子系統(tǒng)的獨(dú)立性和可移植性。當(dāng)你需要構(gòu)建一個(gè)層次結(jié)構(gòu)的子系統(tǒng)時(shí),使用Facade模 式定義子系統(tǒng)中每層的入口點(diǎn)。如果子系統(tǒng)之間是相互依賴的,你可以讓它們僅通過Facade進(jìn)行通 訊,從而簡化了它們之間的依賴關(guān)系。(這里直接引用了設(shè)計(jì)模式迷你手冊,因?yàn)橛X得它確實(shí)已經(jīng)說得很明了了,下面類似的情形我直接引用原文的就不再注明 了,

16、這里先說明一下,感謝手冊作者的這些優(yōu)秀總結(jié)。當(dāng)然,本文的絕大多數(shù)文字都是Teddy本 人的原創(chuàng)看法,絕非抄襲,您可以比較本文和附件手冊,附件同時(shí)也會提供本文的Word版本下 載。)實(shí)現(xiàn):該 模式的實(shí)現(xiàn)需要定義一個(gè)新的系統(tǒng)構(gòu)架上的Layer,該層向上提供一組新的接口,向下調(diào)用子系統(tǒng)原 有的接口。重構(gòu)成本:高。要修改所有直接對子系統(tǒng)的地調(diào)用為對Façade層的調(diào)用還是 有很多事情要做的。不過,現(xiàn)代IDE中,如果我們刪除調(diào)用層對子系統(tǒng)的程序集引用,那么所有這些我 們需要修改的調(diào)用都能標(biāo)示出來,因?yàn)榫幾g不能通過了嘛,因此,重構(gòu)的風(fēng)險(xiǎn)還不算特別大,只是工作量著實(shí)不小。2.6Flyweight思

17、想:說Flyweight可 能有的朋友第一次看到想象不到是什么樣子,其實(shí)說他就是一個(gè)Pool,你可能就明白了。也就是由一 個(gè)Flyweight Factory來管理一族一定數(shù)目邏輯上經(jīng)常需要構(gòu)建和銷毀的細(xì)顆粒對象, 例如我們常見的數(shù)據(jù)庫連接池。在Factory內(nèi)部,并不物理銷毀這些對象,而在接到實(shí)例化請求時(shí) 返回這些被關(guān)系對象的實(shí)例,從而減少創(chuàng)建銷毀這些細(xì)顆粒對象的開銷。場景:基 本上所有的需要Pool這個(gè)概念的環(huán)境都能應(yīng)用。實(shí)現(xiàn):實(shí)現(xiàn)的底層方式可以千變?nèi)f化,在接口上就是如上圖所示,花樣不多。這里就不多解釋。重構(gòu)成本:低。2.7 Proxy思想:前 面在Decorator模式中也提到了Prox

18、y模 式了。它是通過邏輯上繼承一個(gè)已有類的子類,從而擴(kuò)展原有的子類的功能。場景:需 要注意體會他和Decorator的需別。Proxy是 繼承需要修飾的類,而Decorator用的是包含的方式。Proxy模 式,或者準(zhǔn)確地說DynamicProxy模式,是現(xiàn)代AOP框 架實(shí)現(xiàn)中的一種常用方式。典型的實(shí)現(xiàn)如Spring,JBoss以 及Castle Project中的Aspect#。實(shí)現(xiàn):繼承,并在過載方法中添加需要的修飾功能。重構(gòu)成本:低。3 行為型3.1 Interpreter思想:當(dāng) 有一個(gè)語言需要解釋執(zhí)行, 并且你可將該語言中的句子表示為一個(gè)抽象語法樹時(shí),定義一個(gè)解釋器,這 個(gè)解釋器使用

19、該表示來解釋語言中的句子。場景:其 實(shí),從物理結(jié)構(gòu)上,該模式的代碼架構(gòu)看起來可能和Composite模式一模一樣,致使其針對的邏 輯語義不同。Composite模式描述一種一般的整體和部分使用接口上的一致性,而Interpreter模 式則側(cè)重于語言解釋器的實(shí)現(xiàn)構(gòu)架。實(shí)現(xiàn):如 上圖,基本同Composite模式。重構(gòu)成本:高。3.2Iterator思想:提 供一種方法順序訪問一個(gè)聚合對象中各個(gè)元素, 而又不需暴露該對象的內(nèi)部表示。場景:訪 問一個(gè)聚合對象的內(nèi)容而無需暴露它的內(nèi)部表示。支持對聚合對象的多種遍歷。為遍歷不同的聚合結(jié)構(gòu)提供一個(gè)統(tǒng)一的接口(即, 支持多態(tài)迭代)。實(shí)現(xiàn):其 實(shí)就是定義一個(gè)

20、邏輯上類似一個(gè)指針的迭代類。專門用于這種迭代工作。如果對C+ STL火鍋功夫 學(xué)習(xí)的朋友一定不會陌生啦。實(shí)際使用過一下就明白了。除了功能之外,他給我最大的感受就是他讓我熟悉的for(int i = 0; i < list.Count; i+)語句,變長了好多。-重構(gòu)成本:中。3.3Mediator思想:用一個(gè)中介對象來封裝一系列的對象交互。中介者使各對象不需要顯式地相互引用,從而使其耦合松散,而且可以獨(dú)立地改變它們之間的交互。場景:該模式主要用來進(jìn)行降低一組相互關(guān)聯(lián)調(diào)用的對象間的耦合度。如果您發(fā)現(xiàn)您的系統(tǒng)的某部分的一組對象間調(diào)用極其頻繁的壞味道的話,可能您 需要考慮使用該模式來進(jìn)行一些解

21、耦,否則,這些對象中的任何一個(gè)的修改,都將可能導(dǎo)致其他對象許多地方的修改,可維護(hù)性就降低了。實(shí)現(xiàn):定義一個(gè)專門的中介對象來封裝和傳遞一組對象間的調(diào)用。重構(gòu)成本:中。3.4Memento思想:用在不破壞封裝性的前提下,捕獲一個(gè)對象的內(nèi)部狀態(tài),并在該對象之外保存這個(gè)狀態(tài)。這樣以后就可將該對象恢復(fù)到原先保存的狀態(tài)。場景:該 模式主要用來實(shí)現(xiàn)類似我們在常見的編輯器中經(jīng)常執(zhí)行的Undo(Ctrl+Z) 操作。實(shí)際上就是在外部保持一組對象的某一時(shí)刻的狀態(tài),并在需要的另一個(gè)時(shí)候?qū)⑦@組對象回復(fù)到之前的狀態(tài)。實(shí)現(xiàn):該 模式其實(shí)主要是一種對象狀態(tài)的暫存和回復(fù)的思想。上面的UML圖是一種比較典型的實(shí)現(xiàn)方式定一 個(gè)專

22、門用于保存類狀態(tài)的類,為被保存狀態(tài)的類定義返回當(dāng)前狀態(tài)類實(shí)例,和根據(jù)狀態(tài)類實(shí)例回復(fù)對象狀態(tài)的接口。實(shí)際上也不必太拘泥于這個(gè)實(shí)現(xiàn),簡單情形下, 我們完全可以利用任何的已有的對象持久化或者序列化機(jī)制來用一個(gè)字符串暫存對象的當(dāng)前完整狀態(tài)。重構(gòu)成本:低。3.5 Template Method思想:定 義一個(gè)操作中的算法的骨架,而將一些步驟延遲到子類中。Te m p l a t e M e t h o d 使 得子類可以不改變一個(gè)算法的結(jié)構(gòu)即可重定義該算法的某些特定步驟。場景:該 模式實(shí)際上是一種非常直觀和可理解的OO思想下的代碼重用的實(shí)現(xiàn)。只需一次性實(shí)現(xiàn)一個(gè)算法的不變的 部分,并將可變的行為留給子類來

23、實(shí)現(xiàn)。各子類中公共的行為應(yīng)被提取出來并集中到一個(gè)公共父類中以避免代碼重復(fù)。模板方法只允許在特定點(diǎn)計(jì)算法的某個(gè)階段被 過載,這樣也就只允許在這些點(diǎn)進(jìn)行擴(kuò)展。實(shí)現(xiàn):見上圖,太簡單了,就不多說了。重構(gòu)成本:低。3.6 Chain of Responsibility思想:使多個(gè)對象都有機(jī)會處理請求,從而避免請求的發(fā)送者和接收者之間的耦合關(guān)系。將這些對象連成一條鏈,并沿著這條鏈傳遞該請求,直到有一 個(gè)對象處理它為止。場景:該模式實(shí)際上是對人們常會不自覺地去做的一種代碼組織方式的總結(jié)而已。有的時(shí)候一條消息需要被處理,我們當(dāng)然可以在一個(gè)雷的一個(gè)方法中 對他進(jìn)行所有需要的處理。但是,如果要做的處理很復(fù)雜的情形

24、,甚至能夠按照一定的邏輯醒來分類所有這些處理,則不要在一個(gè)雷一個(gè)函數(shù)里處以一切會更好,我 們可以定義多個(gè)處理類類表示邏輯上的不同的處理,然后一個(gè)個(gè)處理類的傳遞這個(gè)消息對象,讓希望處理該消息的類自己決定是不是要處理。這樣,就能將一個(gè)難以 維護(hù)的復(fù)雜處理過程,分解為一系列簡單明了,易于維護(hù)的類了。實(shí)現(xiàn):上圖是實(shí)現(xiàn)方式之一。即,使所有可能處理該請求的對象繼承自一個(gè)基類,實(shí)際上,只要邏輯語義上我們保持這樣一種讓每個(gè)處理類自己決定何 時(shí)處理,并傳遞請求的思想,實(shí)現(xiàn)方式也可以千變?nèi)f化,無論是用接口代替,或者甚至只是簡單的定義相同結(jié)構(gòu)的處理函數(shù)而通過反射機(jī)制來調(diào)用處理函數(shù)和傳遞處 理請求,都是可選的方案。重

25、構(gòu)成本:中。3.7Command思想:將一個(gè)動態(tài)的執(zhí)行過程封裝成一個(gè)對象,可以像處理數(shù)據(jù)來處理和管理這樣的對象,在需要的時(shí)候激發(fā)該對象的方法就能執(zhí)行被封裝的執(zhí)行過 程。場景:該模式在很多時(shí)候非常有用,它使得我們對邏輯上已經(jīng)激發(fā)的行為進(jìn)行優(yōu)化成為可能,我們不僅可以根據(jù)需要改變一組邏輯上以經(jīng)濟(jì)法的活動的 順序,消冗余操作,撤銷不必要的操作等。也可以把活動和操作視為資源一樣來管理和重用。同時(shí)該模式也是許多事務(wù)處理機(jī)制的基礎(chǔ)。實(shí)現(xiàn):實(shí)現(xiàn)很簡單,只是定義一些能夠通過指定接口被激發(fā)的對活動進(jìn)行封裝的類,然后我們按照需要管理這些類,并在需要的時(shí)候激發(fā)這些活動。您 還是應(yīng)該更多地去體會,為什么他是事務(wù)處理機(jī)制

26、的基礎(chǔ),當(dāng)我們可以這樣來管理一組活動的時(shí)候,可以對這些活動進(jìn)行那些有趣的控制。重構(gòu)成本:高。3.8Observer思想:定 義對象間的一種一對多的依賴關(guān)系,當(dāng)一個(gè)對象的狀態(tài)發(fā)生改變時(shí), 所 有依賴于它的對象都得到通知并被自動更新。場景:上面描述該模式思想的文字可能顯得有些拗口,實(shí)際上你也不用想得過于復(fù)雜。只要你寫過任何的基于圖形界面的程序,那么實(shí)際上您對他是一 點(diǎn)也不該陌生的。它就是我們每一次鼠標(biāo)鍵盤敲擊都在我們的程序內(nèi)部流轉(zhuǎn)著的事件機(jī)制的基礎(chǔ)。當(dāng)一個(gè)事件發(fā)生,則通知訂閱該事件的對象。實(shí)現(xiàn):上 面的UML圖看似復(fù)雜,實(shí)際上,去理解它的最好的辦法就是試著思考和使用任何一種OO語 言來定義一個(gè)擁有事件機(jī)制的類。比如,.Net下,你只要好好去看看關(guān)于delegate的 文檔,嘗試著根據(jù)MSDN寫寫看一個(gè)最簡單的自定義事件。那么,上面的UML圖, 我敢保證你能很輕易的看明白。重構(gòu)成本:高。3.9 State思想:允許一個(gè)對象在其內(nèi)部狀態(tài)改變時(shí)

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論