版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、設(shè)計模式的分類設(shè)計模式的分類1.抽象工廠抽象工廠AbstractFACTY廠模式:客戶類和工廠類分開,把各種需要使用到的實(shí)例的創(chuàng)建方法統(tǒng)一單獨(dú)寫成抽象類,實(shí)現(xiàn)類具體實(shí)現(xiàn)創(chuàng)建過程,創(chuàng)建出來的對象類型用接口來表示,抽象工廠可以用在高層類中使用,不用考慮太多具體的創(chuàng)建細(xì)節(jié),如何創(chuàng)建由工廠的具體實(shí)現(xiàn)去定義。核心工廠類不再負(fù)責(zé)所有產(chǎn)品的創(chuàng)建,而是將具體創(chuàng)建的工作交給子類去做,成為一個抽象工廠角色,僅負(fù)責(zé)給出具體工廠類必須實(shí)現(xiàn)的接口,而不接觸哪一個
2、產(chǎn)品類應(yīng)當(dāng)被實(shí)例化這種細(xì)節(jié)。2.BUILDER建造模式:將產(chǎn)品的內(nèi)部表象和產(chǎn)品的生成過程分割開來,從而使一個建造過程生成具有不同的內(nèi)部表象的產(chǎn)品對象。建造模式使得產(chǎn)品內(nèi)部表象可以獨(dú)立的變化,客戶不必知道產(chǎn)品內(nèi)部組成的細(xì)節(jié)。建造模式可以強(qiáng)制實(shí)行一種分步驟進(jìn)行的建造過程。3.FACTYMETHOD工廠方法模式:用一個方法來創(chuàng)建所需要的所有實(shí)例,跟抽象工廠的區(qū)別,就是不需要單獨(dú)寫個工廠類,相當(dāng)于把抽象工廠類里面定義的抽象方法,合并到應(yīng)用類里面
3、,子類去實(shí)現(xiàn)就好了,比抽象工廠更簡潔。4.PROTOTYPE原始模型模式:通過給出一個原型對象來指明所要創(chuàng)建的對象的類型,然后用復(fù)制這個原型對象的方法創(chuàng)建出更多同類型的對象。原始模型模式允許動態(tài)的增加或減少產(chǎn)品類,產(chǎn)品類不需要非得有任何事先確定的等級結(jié)構(gòu),原始模型模式適用于任何的等級結(jié)構(gòu)。缺點(diǎn)是每一個類都必須配備一個克隆方法。5.SINGLETON單例模式:單例模式確保某一個類只有一個實(shí)例,而且自行實(shí)例化并向整個系統(tǒng)提供這個實(shí)例單例模式
4、。單例模式只應(yīng)在有真正的“單一實(shí)例”的需求時才可使用。6.ADAPTER適配器(變壓器)模式:把一個類的接口變換成客戶端所期待的另一種接口,從而使原本因接口原因不匹配而無法一起工作的兩個類能夠一起工作。適配類可以根據(jù)參數(shù)返還一個合適的實(shí)例給客戶端。7.BRIDGE橋梁模式:將抽象化與實(shí)現(xiàn)化脫耦,使得二者可以獨(dú)立的變化,也就是說將他們之間的強(qiáng)關(guān)聯(lián)變成弱關(guān)聯(lián),也就是指在一個軟件系統(tǒng)的抽象化和實(shí)現(xiàn)化之間使用組合聚合關(guān)系而不是繼承關(guān)系,從而使兩
5、者可以獨(dú)立的變化。POSITE責(zé)任鏈模式:在責(zé)任鏈模式中,很多對象由每一個對象對其下家的引用而接起來形成一條鏈。請求在這個鏈上傳遞,直到鏈上的某一個對象決定處理此請求??蛻舨⒉恢梨溕系哪囊粋€對象最終處理這個請求,系統(tǒng)可以在不影響客戶端的情況下動態(tài)的重新組織鏈和分配責(zé)任。處理者有兩個選擇:承擔(dān)責(zé)任或者把責(zé)任推給下家。一個請求可以最終不被任何接收端對象所接受。《設(shè)計模式》中給它的定義如下:使多個對象都有機(jī)會處理請求,從而避免請求的發(fā)送者和
6、接收者之間的耦合關(guān)系。將這些對象連成一條鏈,并沿著這條鏈傳遞該請求,直到有一個對象處理它為止。從定義上可以看出,責(zé)任鏈模式的提出是為了“解耦”,以應(yīng)變系統(tǒng)需求的變更和不明確性。14.COMM命令模式:命令模式把一個請求或者操作封裝到一個對象中。命令模式把發(fā)出命令的責(zé)任和執(zhí)行命令的責(zé)任分割開,委派給不同的對象。命令模式允許請求的一方和發(fā)送的一方獨(dú)立開來,使得請求的一方不必知道接收請求的一方的接口,更不必知道請求是怎么被接收,以及操作是否執(zhí)
7、行,何時被執(zhí)行以及是怎么被執(zhí)行的。系統(tǒng)支持命令的撤消。15.INTERPRETER解釋器模式:給定一個語言后,解釋器模式可以定義出其文法的一種表示,并同時提供一個解釋器??蛻舳丝梢允褂眠@個解釋器來解釋這個語言中的句子。解釋器模式將描述怎樣在有了一個簡單的文法后,使用模式設(shè)計解釋這些語句。在解釋器模式里面提到的語言是指任何解釋器對象能夠解釋的任何組合。在解釋器模式中需要定義一個代表文法的命令類的等級結(jié)構(gòu),也就是一系列的組合規(guī)則。每一個命令
8、對象都有一個解釋方法,代表對命令對象的解釋。命令對象的等級結(jié)構(gòu)中的對象的任何排列組合都是一個語言。16.ITERAT迭代子模式:迭代子模式可以順序訪問一個聚集中的元素而不必暴露聚集的內(nèi)部表象。多個對象聚在一起形成的總體稱之為聚集,聚集對象是能夠包容一組對象的容器對象。迭代子模式將迭代邏輯封裝到一個獨(dú)立的子對象中,從而與聚集本身隔開。迭代子模式簡化了聚集的界面。每一個聚集對象都可以有一個或一個以上的迭代子對象,每一個迭代子的迭代狀態(tài)可以是
9、彼此獨(dú)立的。迭代算法可以獨(dú)立于聚集角色變化。17.MEDIAT調(diào)停者模式:調(diào)停者模式包裝了一系列對象相互作用的方式,使得這些對象不必相互明顯作用。從而使他們可以松散偶合。當(dāng)某些對象之間的作用發(fā)生改變時,不會立即影響其他的一些對象之間的作用。保證這些作用可以彼此獨(dú)立的變化。調(diào)停者模式將多對多的相互作用轉(zhuǎn)化為一對多的相互作用。調(diào)停者模式將對象的行為和協(xié)作抽象化,把對象在小尺度的行為上與其他對象的相互作用分開處理。適用的情況舉例eg1.WTO
溫馨提示
- 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. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- java23種設(shè)計模式
- java23種設(shè)計模式(總結(jié))
- java23種開發(fā)模式
- 設(shè)置模式23種類圖
- 23模式
- 大規(guī)模軟件中23種設(shè)計模式應(yīng)用規(guī)律的研究與分析.pdf
- 23種醒酒妙計
- 23種蜂蜜美容法
- java種設(shè)計模式總結(jié)
- 四種薪酬設(shè)計模式
- 23種經(jīng)典客戶轉(zhuǎn)介紹秘訣
- 核桃仁的23種吃法
- toefl作文常見的23種錯誤
- 23個設(shè)計模式c#代碼 第18章 觀察者模式(oberver pattern)
- 導(dǎo)航數(shù)據(jù)庫23種航段定義
- 六種微服務(wù)架構(gòu)的設(shè)計模式
- 8種營銷模式
- 融資30種模式
- 象棋開局的必勝走法(23種)秘籍圖文
- 選煤廠23種常見設(shè)備故障處理辦法
評論
0/150
提交評論