最易懂設(shè)計(jì)模式解析


適配器設(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ù)。
  1. 設(shè)計(jì)模式不是一成不變的雅采,而是在不斷發(fā)展中慨亲。
  2. 設(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)閉。
  1. 程序設(shè)計(jì)要保證平滑性的擴(kuò)展性呐伞,盡量避免因?yàn)樾略鐾惞δ芏薷囊延袑?shí)現(xiàn),這樣可以少產(chǎn)出回歸問(wèn)題慎式。
  2. 抽象化是開(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)。
  1. 也就是說(shuō)侈贷,在程序代碼中傳遞參數(shù)時(shí)或在關(guān)聯(lián)關(guān)系中等脂,盡量引用層次高的抽象層類,即使用接口和抽象類進(jìn)行變量類型聲明搏屑、參數(shù)類型聲明粉楚、方法返回類型聲明,以及數(shù)據(jù)類型的轉(zhuǎn)換等模软,而不要用具體類來(lái)做這些事情。這一原則是降低產(chǎn)品代碼之間的耦合携狭。
  2. 在程序中盡量使用抽象層進(jìn)行編程回俐,而將具體類寫在配置文件中壹瘟,這樣一來(lái)鳄逾,如果系統(tǒng)行為發(fā)生變化,只需要對(duì)抽象層進(jìn)行擴(kuò)展殴俱,并修改配置文件枚抵,而無(wú)須修改原有系統(tǒng)的源代碼,在不修改的情況下來(lái)擴(kuò)展系統(tǒng)的功能汽摹,滿足開(kāi)閉原則的要求。
  3. 在實(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)的耦合度。
  1. 迪米特法則還有幾種定義形式拇厢,包括:不要和“陌生人”說(shuō)話、只與你的直接朋友通信等孝偎。
  2. 迪米特法則中對(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ì)象。
  3. 迪米特法則運(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í)逻杖。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末弧腥,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子虾攻,更是在濱河造成了極大的恐慌更鲁,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,858評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件漂坏,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡顶别,警方通過(guò)查閱死者的電腦和手機(jī)驯绎,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,372評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)屈尼,“玉大人拴孤,你說(shuō)我怎么就攤上這事⊙菔欤” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,282評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵蚕冬,是天一觀的道長(zhǎng)是辕。 經(jīng)常有香客問(wèn)我获三,道長(zhǎng),這世上最難降的妖魔是什么疙教? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,842評(píng)論 1 295
  • 正文 為了忘掉前任贞谓,我火速辦了婚禮,結(jié)果婚禮上裸弦,老公的妹妹穿的比我還像新娘。我一直安慰自己晕城,他們只是感情好窖贤,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,857評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著滤蝠,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上粤攒,一...
    開(kāi)封第一講書(shū)人閱讀 51,679評(píng)論 1 305
  • 那天夯接,我揣著相機(jī)與錄音,去河邊找鬼盔几。 笑死逊拍,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的芯丧。 我是一名探鬼主播,決...
    沈念sama閱讀 40,406評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼谴咸,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼骗露!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起珊随,我...
    開(kāi)封第一講書(shū)人閱讀 39,311評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤柿隙,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后京办,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體帆焕,經(jīng)...
    沈念sama閱讀 45,767評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評(píng)論 3 336
  • 正文 我和宋清朗相戀三年换吧,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了钥星。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,090評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡贯莺,死狀恐怖宁改,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情还蹲,我是刑警寧澤,帶...
    沈念sama閱讀 35,785評(píng)論 5 346
  • 正文 年R本政府宣布潭兽,位于F島的核電站斗遏,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏怒坯。R本人自食惡果不足惜藻懒,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,420評(píng)論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望归敬。 院中可真熱鬧鄙早,春花似錦、人聲如沸限番。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,988評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)珠插。三九已至,卻和暖如春捻撑,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背番捂。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,101評(píng)論 1 271
  • 我被黑心中介騙來(lái)泰國(guó)打工描验, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留坑鱼,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,298評(píng)論 3 372
  • 正文 我出身青樓呼股,卻偏偏與公主長(zhǎng)得像画恰,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子允扇,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,033評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容