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):
- 一個(gè)類對(duì)一類的依賴應(yīng)該建立在最小的接口之上巡球。
- 建立單一接口,不要建立龐大臃腫的接口邓嘹。
- 盡量細(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ò)展父類的功能厅克,但不能改變父類原有的功能。
- 子類可以實(shí)現(xiàn)父類的抽象方法橙依,但不能覆蓋父類的非抽象方法证舟。
- 子類中可以增加自己特有的方法。
- 當(dāng)子類的方法重載父類的方法時(shí)窗骑,方法的前置條件(即方法的輸入/入?yún)ⅲ┮雀割惙椒ǖ妮斎雲(yún)?shù)更寬松女责。
- 當(dāng)子類的方法實(shí)現(xiàn)父類的方法時(shí)(重寫/重載或?qū)崿F(xiàn)抽象方法),方法的后置條件(即方法的輸出/返回值)要比父類更嚴(yán)格或相等创译。
優(yōu)點(diǎn):
- 約束繼承泛濫抵知,開(kāi)閉原則的一種體現(xiàn)。
- 加強(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 模型奸忽。