適配器設(shè)計(jì)模式
模板方法設(shè)計(jì)模式
Mybatis代理設(shè)計(jì)模式
Mybatis多級(jí)代理
設(shè)計(jì)模式目錄
設(shè)計(jì)模式-圖片來(lái)源網(wǎng)絡(luò)
1. 設(shè)計(jì)模式的概念
- 是指在軟件開(kāi)發(fā)中疫赎,經(jīng)過(guò)驗(yàn)證的,用于解決在特定環(huán)境下捧搞、重復(fù)出現(xiàn)的抵卫、特定問(wèn)題的解決方案狮荔。
- 目的就是確定通用解決方案、確立通用術(shù)語(yǔ)介粘、讓代碼易修改和維護(hù)。
- 設(shè)計(jì)模式不是一成不變的雅采,而是在不斷發(fā)展中慨亲。
- 設(shè)計(jì)模式不是軟件行業(yè)獨(dú)有的,事實(shí)上刑棵,有很多行業(yè)有自己的設(shè)計(jì)模式。
2. 學(xué)習(xí)設(shè)計(jì)模式的好處
- 便于查看高級(jí)框架源碼蛉签。
- 增加解決問(wèn)題的能力。
- 不用重復(fù)發(fā)明輪子柠座。
3. 設(shè)計(jì)模式的設(shè)計(jì)原則
設(shè)計(jì)原則
SOLDIA原則:
-
單一職責(zé)原則(Single Responsibility Principle, SRP):
一個(gè)類或?qū)ο笞詈弥回?fù)責(zé)一個(gè)功能領(lǐng)域的相應(yīng)職責(zé)片橡。
在程序設(shè)計(jì)中如果發(fā)現(xiàn)某個(gè)類承擔(dān)著多種義務(wù),可以進(jìn)行拆分,若多個(gè)職責(zé)總同時(shí)發(fā)生改變則可以將它們封裝到一個(gè)類中录煤。
-
開(kāi)放封閉原則(Open-Closed Principle, OCP):
一個(gè)軟件實(shí)體(模塊妈踊、多個(gè)類組成的局部結(jié)構(gòu)、獨(dú)立的類)應(yīng)該對(duì)擴(kuò)展開(kāi)放廊营,對(duì)修改關(guān)閉。
- 程序設(shè)計(jì)要保證平滑性的擴(kuò)展性呐伞,盡量避免因?yàn)樾略鐾惞δ芏薷囊延袑?shí)現(xiàn),這樣可以少產(chǎn)出回歸問(wèn)題慎式。
- 抽象化是開(kāi)閉原則的關(guān)鍵伶氢,可以通過(guò)它們定義系統(tǒng)的抽象層,再通過(guò)具體類進(jìn)行擴(kuò)展癣防。需要修改系統(tǒng)行為,無(wú)須對(duì)抽象層動(dòng)手幕屹,只需增加新的具體類來(lái)實(shí)現(xiàn)新的業(yè)務(wù)功能即可级遭。
-
里氏代替原則(Liskov Substitution Principle, LSP):
這是面向?qū)ο蟮幕疽刂唬幸没悾ǜ割悾┑牡胤奖仨毮軌蚴褂闷渥宇惖膶?duì)象靠娱。
在軟件開(kāi)發(fā)中掠兄,一個(gè)基類對(duì)象替換成子類對(duì)象,程序不會(huì)產(chǎn)生任何錯(cuò)誤和異常蚂夕。
-
依賴倒置原則(Dependency Inversion Principle, DIP):
實(shí)體應(yīng)該依賴于抽象而不是實(shí)現(xiàn)。
- 也就是說(shuō)侈贷,在程序代碼中傳遞參數(shù)時(shí)或在關(guān)聯(lián)關(guān)系中等脂,盡量引用層次高的抽象層類,即使用接口和抽象類進(jìn)行變量類型聲明搏屑、參數(shù)類型聲明粉楚、方法返回類型聲明,以及數(shù)據(jù)類型的轉(zhuǎn)換等模软,而不要用具體類來(lái)做這些事情。這一原則是降低產(chǎn)品代碼之間的耦合携狭。
- 在程序中盡量使用抽象層進(jìn)行編程回俐,而將具體類寫在配置文件中壹瘟,這樣一來(lái)鳄逾,如果系統(tǒng)行為發(fā)生變化,只需要對(duì)抽象層進(jìn)行擴(kuò)展殴俱,并修改配置文件枚抵,而無(wú)須修改原有系統(tǒng)的源代碼,在不修改的情況下來(lái)擴(kuò)展系統(tǒng)的功能汽摹,滿足開(kāi)閉原則的要求。
- 在實(shí)現(xiàn)依賴倒置原則時(shí)趴泌,則需要針對(duì)抽象層編程拉庶,而將具體類的對(duì)象通過(guò)依賴注入( DI)的方式注入到其他對(duì)象中,依賴注入是指當(dāng)一個(gè)對(duì)象要與其他對(duì)象發(fā)生依賴關(guān)系時(shí)吉捶,通過(guò)抽象來(lái)注入所依賴的對(duì)象皆尔。常用的注入方式有三種,分別是:構(gòu)造注入慷蠕,設(shè)值注入(Setter注入)和接口注入砌们。構(gòu)造注入是指通過(guò)構(gòu)造函數(shù)來(lái)傳入具體類的對(duì)象搁进,設(shè)值注入是指通過(guò)Setter方法來(lái)傳入具體類的對(duì)象,而接口注入是指通過(guò)在接口中聲明的業(yè)務(wù)方法來(lái)傳入具體類的對(duì)象饼问。這些方法在定義時(shí)使用的是抽象類型,在運(yùn)行時(shí)再傳入具體類型的對(duì)象峻堰,由子類對(duì)象來(lái)覆蓋父類對(duì)象。
-
接口隔離原則(Interface Segregation Principle, ISP):
使用多個(gè)專門的接口旦万,而不使用單一的總接口镶蹋,即客戶端不應(yīng)該依賴那些它不需要的接口。
在進(jìn)行類和接口之間的設(shè)計(jì)時(shí)贺归,如果一個(gè)接口定義了太多方法,其子類可能面臨兩難秋冰,就只有部分方法對(duì)它有意義婶熬,這就破壞了程序的內(nèi)聚性。
-
合成復(fù)用原則(Aggregate Reuse Principle, ARP):
盡量使用對(duì)象組合甥材,而不是繼承來(lái)達(dá)到復(fù)用的目的性含。
新對(duì)象通過(guò)委派調(diào)用已有對(duì)象的方法達(dá)到復(fù)用功能的目的。簡(jiǎn)言之:復(fù)用時(shí)要盡量使用組合/聚合關(guān)系(關(guān)聯(lián)關(guān)系)叠萍,少用繼承绪商。
-
迪米特法則/最小知識(shí)原則(LeastKnowledge Principle, LKP)
個(gè)軟件實(shí)體應(yīng)當(dāng)盡可能少地與其他實(shí)體發(fā)生相互作用。這樣系統(tǒng)模塊功能相對(duì)獨(dú)立格郁,當(dāng)其中某一個(gè)模塊發(fā)生修改時(shí),就會(huì)盡量少地影響其他模塊锣尉,擴(kuò)展會(huì)相對(duì)容易决采,降低系統(tǒng)的耦合度。
- 迪米特法則還有幾種定義形式拇厢,包括:不要和“陌生人”說(shuō)話、只與你的直接朋友通信等孝偎。
- 迪米特法則中對(duì)于一個(gè)對(duì)象,其朋友包括以下幾類:
(1) 當(dāng)前對(duì)象本身(this)捐顷;
(2) 以參數(shù)形式傳入到當(dāng)前對(duì)象方法中的對(duì)象雨效;
(3) 當(dāng)前對(duì)象的成員對(duì)象;
(4) 如果當(dāng)前對(duì)象的成員對(duì)象是一個(gè)集合叮姑,那么集合中的元素也都是朋友据悔;
(5) 當(dāng)前對(duì)象所創(chuàng)建的對(duì)象。- 迪米特法則運(yùn)用到系統(tǒng)設(shè)計(jì)中應(yīng)該注意幾點(diǎn):在類的劃分上极颓,應(yīng)當(dāng)盡量創(chuàng)建松耦合的類菠隆,類之間的耦合度越低,就越有利于復(fù)用骇径,一個(gè)處在松耦合中的類一旦被修改,不會(huì)對(duì)關(guān)聯(lián)的類造成太大波及清女;在類的結(jié)構(gòu)設(shè)計(jì)上晰筛,每一個(gè)類都應(yīng)當(dāng)盡量降低其成員變量和成員函數(shù)的訪問(wèn)權(quán)限;在類的設(shè)計(jì)上曙博,只要有可能卦方,一個(gè)類型應(yīng)當(dāng)設(shè)計(jì)成不變類泰佳;在對(duì)其他類的引用上尘吗,一個(gè)對(duì)象對(duì)其他對(duì)象的引用應(yīng)當(dāng)降到最低浇坐。
4. 設(shè)計(jì)模式的分類
GoF著作的23種設(shè)計(jì)模式,對(duì)于這23中設(shè)計(jì)模式GoF把它們分為三類:
23種設(shè)計(jì)模式
常用的設(shè)計(jì)模式有:
- 創(chuàng)建型模式:工廠方法模式擒贸、抽象工廠模式觉渴、建造者模式、單例模式座韵。
- 結(jié)構(gòu)性模式:適配器模式踢京、代理模式。
- 行為型模式:策略模式黔帕、模板方法模式蹈丸、觀察者模式。
可以針對(duì)性的對(duì)這些模式去學(xué)習(xí)逻杖。