單一職責(zé)原則(Single Responsibility Principle, SRP)
核心思想:每一個(gè)對(duì)象應(yīng)該只有一個(gè)單獨(dú)的職責(zé),每個(gè)對(duì)象所關(guān)注的就是自身職責(zé)的完成寓落。
單一職責(zé)原則的意思就是“高聚合茵臭,低耦合”沽瘦。每個(gè)類(lèi)只有一個(gè)職責(zé)啦租,對(duì)外只提供一個(gè)功能煮岁,引起類(lèi)變化的原因就只有一個(gè)讥蔽。
一個(gè)類(lèi)的職責(zé)越多涣易,導(dǎo)致其變化的因素也就越多,其中一個(gè)職責(zé)變化時(shí)冶伞,可能會(huì)影響其他職責(zé)的運(yùn)作新症,因此要將這些職責(zé)進(jìn)行分離,將不同的職責(zé)封裝在不同的類(lèi)中碰缔,即將不同的變化原因封裝在不同的類(lèi)中账劲,如果多個(gè)職責(zé)總是同時(shí)發(fā)生改變則可將它們封裝在同一類(lèi)中。
這樣做會(huì)讓程序變的易于修改和維護(hù)金抡。但這個(gè)過(guò)程可能是困難的瀑焦,因?yàn)槲覀儾荒茌p易的知道哪些職責(zé)會(huì)發(fā)生變化,哪些職責(zé)要被提取出來(lái)梗肝。所以需要一個(gè)演化的過(guò)程榛瓮,讓我們知道哪些職責(zé)需要被提取出來(lái)。
里氏替換原則(Liskov Substitution Princiole,LSP)
核心思想:在任何父類(lèi)出現(xiàn)的地方都可以用它的子類(lèi)替代巫击。
里氏替換原則的意思就是同一個(gè)繼承體系中的對(duì)象都應(yīng)該有共同的行為特征禀晓。LSP所關(guān)注的是怎樣良好的使用繼承。在LSP里坝锰,所有引用基類(lèi)的地方必須能透明的使用其子類(lèi)對(duì)象粹懒。這個(gè)原則為良好的繼承定義了一個(gè)規(guī)范,共有四層含義:
1. 子類(lèi)必須完全實(shí)現(xiàn)父類(lèi)的方法
2. 子類(lèi)可以有自己的特性
3. 覆蓋或?qū)崿F(xiàn)父類(lèi)的方法輸入的參數(shù)可以被放大
4. 覆蓋或?qū)崿F(xiàn)父類(lèi)的方法輸出的參數(shù)可以被放大
依賴(lài)注入原則(Dependency Inversion Principle顷级,DIP)
核心思想:要依賴(lài)于抽象凫乖,不要依賴(lài)于具體的實(shí)現(xiàn)。
依賴(lài)注入原則的意思就是在應(yīng)用程序中弓颈,所有的類(lèi)如果要使用其他的類(lèi)或者依賴(lài)其他是類(lèi)帽芽,都應(yīng)該依賴(lài)他們的抽象類(lèi),而不是實(shí)現(xiàn)類(lèi)翔冀,這樣才能保證系統(tǒng)的可復(fù)用性和可維護(hù)性导街。所以我們?cè)谌粘i_(kāi)發(fā)中要針對(duì)接口編程,而不是針對(duì)實(shí)現(xiàn)編程纤子。
依賴(lài)注入原則有三點(diǎn)說(shuō)明:
- 高層模塊不應(yīng)該依賴(lài)低層模塊搬瑰,兩者都應(yīng)該依賴(lài)于抽象
- 抽象不應(yīng)該依賴(lài)細(xì)節(jié)
- 細(xì)節(jié)應(yīng)該依賴(lài)抽象
依賴(lài)注入原則可以用以下三種方式來(lái)實(shí)現(xiàn):
- 通過(guò)構(gòu)造方法傳遞依賴(lài)對(duì)象
- 通過(guò)set方法傳遞依賴(lài)對(duì)象
- 接口聲明實(shí)現(xiàn)依賴(lài)對(duì)象
接口隔離原則(Interface Segregation Principle,ISP)
核心思想:不應(yīng)該強(qiáng)迫客戶程序依賴(lài)他們不需要的使用的方法控硼。
接口隔離原則的意思就是一個(gè)接口不需要提供太多的行為跌捆,一個(gè)接口應(yīng)該只提供一種對(duì)外的功能,不應(yīng)該把所有的操作封裝在一個(gè)接口中象颖。這里的接口不僅僅是指類(lèi)接口(class interface)佩厚,還指對(duì)象接口(Object interface)通過(guò)new關(guān)鍵字產(chǎn)生的一個(gè)實(shí)例,它是對(duì)一個(gè)類(lèi)型的事務(wù)的描述说订。
接口隔離原則和單一職責(zé)原則有一些相似抄瓦,不過(guò)單一職責(zé)原則注重的是職責(zé)潮瓶,是業(yè)務(wù)邏輯的劃分。而接口隔離原則要求的是接口的方法盡量少钙姊。
在使用接口分離原則的時(shí)候也有一些規(guī)范:
- 接口盡量小
- 接口高內(nèi)聚接口內(nèi)部聲明的方法相互之間都要與某個(gè)子模塊相關(guān)毯辅,而且這個(gè)子模塊是必須的
- 接口設(shè)計(jì)是有限度的,要靠開(kāi)發(fā)者的經(jīng)驗(yàn)去判斷了
最小知識(shí)原則(Principle of Least Knowledge煞额,PLK思恐,迪米特法則)
核心思想:一個(gè)對(duì)象應(yīng)當(dāng)對(duì)其他對(duì)象盡可能少了解。
迪米特原則的意思就是降低各個(gè)對(duì)象之間的耦合膊毁,提高系統(tǒng)的可維護(hù)性胀莹。在模塊之間,應(yīng)該只通過(guò)接口來(lái)通信婚温,這可使各個(gè)模塊耦合程度降到最低描焰,促進(jìn)軟件的復(fù)用。
開(kāi)閉原則(Open Closed Principle栅螟,OCP)
核心思想:一個(gè)對(duì)象對(duì)擴(kuò)展開(kāi)放荆秦,對(duì)修改關(guān)閉。
開(kāi)閉原則的意思就是對(duì)類(lèi)的改動(dòng)是通過(guò)增加代碼實(shí)現(xiàn)的力图,而不是改動(dòng)原先的代碼步绸。