學(xué)習(xí)筆記-7.七大軟件設(shè)計(jì)原則

7.七大軟件設(shè)計(jì)原則

7.1 開(kāi)閉原則

開(kāi)閉原則(Open-Closed Principle, OCP)是指一個(gè)軟件實(shí)體如類、模塊和函數(shù)應(yīng)該對(duì)擴(kuò)展開(kāi)放九府,對(duì)修改關(guān)閉。所謂的開(kāi)閉覆致,也正是對(duì)擴(kuò)展和修改兩個(gè)行為的一個(gè)原則侄旬。強(qiáng)調(diào)的是用抽象構(gòu)建框架,用實(shí)現(xiàn)擴(kuò)展細(xì)節(jié)煌妈±芨幔可以提高軟件系統(tǒng)的可復(fù)用性及可維護(hù)性。開(kāi)閉原則璧诵,是面向?qū)ο笤O(shè)計(jì)中最基礎(chǔ)的設(shè)計(jì)原則汰蜘。它指導(dǎo)我們?nèi)绾谓⒎€(wěn)定靈活的系統(tǒng),例如:我們版本更新之宿,我盡可能不修改源代碼族操,但是可以增加新功能。

7.2 依賴倒置原則

依賴倒置原則(Dependence Inversion Principle,DIP)是指設(shè)計(jì)代碼結(jié)構(gòu)時(shí)澈缺,高層模塊不應(yīng)該依賴底層模塊坪创,二者都應(yīng)該依賴其抽象。抽象不應(yīng)該依賴細(xì)節(jié)姐赡;細(xì)節(jié)應(yīng)該依賴抽象莱预。

優(yōu)點(diǎn):通過(guò)依賴倒置,可以減少類與類之間的耦合性项滑,提高系統(tǒng)的穩(wěn)定性依沮,提高代碼的可讀性和可維護(hù)性,并能夠降低修改程序所造成的風(fēng)險(xiǎn)枪狂。

7.3 單一職責(zé)原則

單一職責(zé)(Simple Responsibility Pinciple危喉,SRP)是指不要存在多于一個(gè)導(dǎo)致類變更的原因。假設(shè)我們有一個(gè) Class 負(fù)責(zé)兩個(gè)職責(zé)州疾,一旦發(fā)生需求變更辜限,修改其中一個(gè)職責(zé)的邏輯代碼,有可能會(huì)導(dǎo)致另一個(gè)職責(zé)的功能發(fā)生故障严蓖。這樣一來(lái)薄嫡,這個(gè) Class 存在兩個(gè)導(dǎo)致類變更的原因氧急。如何解決這個(gè)問(wèn)題呢?我們就要給兩個(gè)職責(zé)分別用兩個(gè) Class 來(lái)實(shí)現(xiàn)毫深,進(jìn)行解耦吩坝。后期需求變更維護(hù)互不影響。這樣的設(shè)計(jì)哑蔫,

優(yōu)點(diǎn):降低類的復(fù)雜度钉寝,提高類的可 讀 性 , 提 高 系 統(tǒng) 的 可 維 護(hù) 性 闸迷, 降 低 變 更 引 起 的 風(fēng) 險(xiǎn) 嵌纲。 總 體 來(lái) 說(shuō) 就 是 一個(gè)Class/Interface/Method 只負(fù)責(zé)一項(xiàng)職責(zé)。

7.4 接口隔離原則

接口隔離原則(Interface Segregation Principle, ISP)是指用多個(gè)專門的接口稿黍,而不使用單一的總接口疹瘦,客戶端不應(yīng)該依賴它不需要的接口崩哩。這個(gè)原則指導(dǎo)我們?cè)谠O(shè)計(jì)接口時(shí)應(yīng)當(dāng)注意一下幾點(diǎn):

  1. 一個(gè)類對(duì)一類的依賴應(yīng)該建立在最小的接口之上巡球。
  2. 建立單一接口,不要建立龐大臃腫的接口邓嘹。
  3. 盡量細(xì)化接口酣栈,接口中的方法盡量少(不是越少越好,一定要適度)汹押。

接口隔離原則符合我們常說(shuō)的高內(nèi)聚矿筝、低耦合的設(shè)計(jì)思想,從而使得類具有很好的可讀性棚贾、可擴(kuò)展性和可維護(hù)性窖维。我們?cè)谠O(shè)計(jì)接口的時(shí)候,要多花時(shí)間去思考妙痹,要考慮業(yè)務(wù)模型铸史,包括以后有可能發(fā)生變更的地方還要做一些預(yù)判。所以怯伊,對(duì)于抽象琳轿,對(duì)業(yè)務(wù)模型的理解是非常重要的。

7.5 迪米特法則

迪米特原則(Law of Demeter LoD)是指一個(gè)對(duì)象應(yīng)該對(duì)其他對(duì)象保持最少的了解耿芹,又叫最少知道原則(Least Knowledge Principle,LKP)崭篡,盡量降低類與類之間的耦合。迪米特原則主要強(qiáng)調(diào)只和朋友交流吧秕,不和陌生人說(shuō)話琉闪。出現(xiàn)在成員變量、方法的輸入砸彬、輸出參數(shù)中的類都可以稱之為成員朋友類颠毙,而出現(xiàn)在方法體內(nèi)部的類不屬于朋友類疗涉。

7.6 里氏替換原則

里氏替換原則(Liskov Substitution Principle,LSP)是指如果對(duì)每一個(gè)類型為 T1 的
對(duì)象 o1,都有類型為 T2 的對(duì)象 o2,使得以 T1 定義的所有程序 P 在所有的對(duì)象 o1 都替換成 o2 時(shí),程序 P 的行為沒(méi)有發(fā)生變化吟秩,那么類型 T2 是類型 T1 的子類型咱扣。
定義看上去還是比較抽象,我們重新理解一下涵防,可以理解為一個(gè)軟件實(shí)體如果適用一
個(gè)父類的話闹伪,那一定是適用于其子類,所有引用父類的地方必須能透明地使用其子類的對(duì)象壮池,子類對(duì)象能夠替換父類對(duì)象偏瓤,而程序邏輯不變。根據(jù)這個(gè)理解椰憋,我們總結(jié)一下:
引申含義:子類可以擴(kuò)展父類的功能厅克,但不能改變父類原有的功能。

  1. 子類可以實(shí)現(xiàn)父類的抽象方法橙依,但不能覆蓋父類的非抽象方法证舟。
  2. 子類中可以增加自己特有的方法。
  3. 當(dāng)子類的方法重載父類的方法時(shí)窗骑,方法的前置條件(即方法的輸入/入?yún)ⅲ┮雀割惙椒ǖ妮斎雲(yún)?shù)更寬松女责。
  4. 當(dāng)子類的方法實(shí)現(xiàn)父類的方法時(shí)(重寫/重載或?qū)崿F(xiàn)抽象方法),方法的后置條件(即方法的輸出/返回值)要比父類更嚴(yán)格或相等创译。

優(yōu)點(diǎn):

  1. 約束繼承泛濫抵知,開(kāi)閉原則的一種體現(xiàn)。
  2. 加強(qiáng)程序的健壯性软族,同時(shí)變更時(shí)也可以做到非常好的兼容性刷喜,提高程序的維護(hù)性、擴(kuò)展性立砸。降低需求變更時(shí)引入的風(fēng)險(xiǎn)掖疮。

7.7 合成復(fù)用原則

合成復(fù)用原則(Composite/Aggregate Reuse Principle,CARP)是指盡量使用對(duì)象組合(has-a)/聚合(contanis-a),而不是繼承關(guān)系達(dá)到軟件復(fù)用的目的仰禽〉可以使系統(tǒng)更加靈活,降低類與類之間的耦合度吐葵,一個(gè)類的變化對(duì)其他類造成的影響相對(duì)較少规揪。 繼承我們叫做白箱復(fù)用,相當(dāng)于把所有的實(shí)現(xiàn)細(xì)節(jié)暴露給子類温峭。組合/聚合也稱之為黑箱復(fù)用猛铅,對(duì)類以外的對(duì)象是無(wú)法獲取到實(shí)現(xiàn)細(xì)節(jié)的。要根據(jù)具體的業(yè)務(wù)場(chǎng)景來(lái)做代碼設(shè)計(jì)凤藏,其實(shí)也都需要遵循 OOP 模型奸忽。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末堕伪,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子栗菜,更是在濱河造成了極大的恐慌欠雌,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,525評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件疙筹,死亡現(xiàn)場(chǎng)離奇詭異富俄,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)而咆,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,203評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門霍比,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人暴备,你說(shuō)我怎么就攤上這事悠瞬。” “怎么了涯捻?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,862評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵浅妆,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我汰瘫,道長(zhǎng)狂打,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,728評(píng)論 1 294
  • 正文 為了忘掉前任混弥,我火速辦了婚禮,結(jié)果婚禮上对省,老公的妹妹穿的比我還像新娘蝗拿。我一直安慰自己,他們只是感情好蒿涎,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,743評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布哀托。 她就那樣靜靜地躺著,像睡著了一般劳秋。 火紅的嫁衣襯著肌膚如雪仓手。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,590評(píng)論 1 305
  • 那天玻淑,我揣著相機(jī)與錄音嗽冒,去河邊找鬼。 笑死补履,一個(gè)胖子當(dāng)著我的面吹牛添坊,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播箫锤,決...
    沈念sama閱讀 40,330評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼贬蛙,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼雨女!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起阳准,我...
    開(kāi)封第一講書(shū)人閱讀 39,244評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤氛堕,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后野蝇,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體岔擂,經(jīng)...
    沈念sama閱讀 45,693評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,885評(píng)論 3 336
  • 正文 我和宋清朗相戀三年浪耘,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了乱灵。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,001評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡七冲,死狀恐怖痛倚,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情澜躺,我是刑警寧澤蝉稳,帶...
    沈念sama閱讀 35,723評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站掘鄙,受9級(jí)特大地震影響耘戚,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜操漠,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,343評(píng)論 3 330
  • 文/蒙蒙 一收津、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧浊伙,春花似錦撞秋、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,919評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至哑子,卻和暖如春舅列,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背卧蜓。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,042評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工帐要, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人烦却。 一個(gè)月前我還...
    沈念sama閱讀 48,191評(píng)論 3 370
  • 正文 我出身青樓宠叼,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子冒冬,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,955評(píng)論 2 355

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