一、六大原則
1.1單一職責(zé)原則(Single Responsibility Principle雏亚,簡稱SRP )
核心思想: 應(yīng)該有且僅有一個原因引起類的變更
問題描述: 假如有類Class1完成職責(zé)T1,T2,當(dāng)職責(zé)T1或T2有變更需要修改時新症,有可能影響到該類的另外一個職責(zé)正常工作
1.2里氏替換原則(Liskov Substitution Principle,簡稱LSP)
核心思想: 在使用基類的的地方可以任意使用其子類,能保證子類完美替換基類响禽。
通俗來講: 只要父類能出現(xiàn)的地方子類就能出現(xiàn)徒爹。反之,父類則未必能勝任金抡。
1.3依賴倒置原則(Dependence Inversion Principle,簡稱DIP)
核心思想:高層模塊不應(yīng)該依賴底層模塊瀑焦,二者都該依賴其抽象;抽象不應(yīng)該依賴細(xì)節(jié)梗肝;細(xì)節(jié)應(yīng)該依賴抽象榛瓮;
說明:高層模塊就是調(diào)用端,低層模塊就是具體實(shí)現(xiàn)類巫击。抽象就是指接口或抽象類禀晓。細(xì)節(jié)就是實(shí)現(xiàn)類。
通俗來講: 依賴倒置原則的本質(zhì)就是通過抽象(接口或抽象類)使個各類或模塊的實(shí)現(xiàn)彼此獨(dú)立坝锰,互不影響粹懒,實(shí)現(xiàn)模塊間的松耦合。
問題描述: 類A直接依賴類B顷级,假如要將類A改為依賴類C凫乖,則必須通過修改類A的代碼來達(dá)成。這種場景下,類A一般是高層模塊帽芽,負(fù)責(zé)復(fù)雜的業(yè)務(wù)邏輯删掀;類B和類C是低層模塊,負(fù)責(zé)基本的原子操作导街;假如修改類A披泪,會給程序帶來不必要的風(fēng)險。
解決方案: 將類A修改為依賴接口interface搬瑰,類B和類C各自實(shí)現(xiàn)接口interface款票,類A通過接口interface間接與類B或者類C發(fā)生聯(lián)系,則會大大降低修改類A的幾率泽论。
1.4接口隔離原則(Interface Segregation Principle,簡稱ISP)
核心思想:類間的依賴關(guān)系應(yīng)該建立在最小的接口上
通俗來講: 建立單一接口艾少,不要建立龐大臃腫的接口,盡量細(xì)化接口佩厚,接口中的方法盡量少姆钉。也就是說,我們要為各個類建立專用的接口抄瓦,而不要試圖去建立一個很龐大的接口供所有依賴它的類去調(diào)用潮瓶。
問題描述: 類A通過接口interface依賴類B,類C通過接口interface依賴類D钙姊,如果接口interface對于類A和類B來說不是最小接口毯辅,則類B和類D必須去實(shí)現(xiàn)他們不需要的方法。
1.5迪米特法則(Law of Demeter,簡稱LoD)
核心思想: 類間解耦煞额。
通俗來講: 一個類對自己依賴的類知道的越少越好思恐。自從我們接觸編程開始,就知道了軟件編程的總的原則:低耦合膊毁,高內(nèi)聚胀莹。無論是面向過程編程還是面向?qū)ο缶幊蹋挥惺垢鱾€模塊之間的耦合盡量的低婚温,才能提高代碼的復(fù)用率描焰。低耦合的優(yōu)點(diǎn)不言而喻,但是怎么樣編程才能做到低耦合呢栅螟?那正是迪米特法則要去完成的荆秦。
6、開放封閉原則(Open Close Principle,簡稱OCP)
核心思想: 盡量通過擴(kuò)展軟件實(shí)體來解決需求變化力图,而不是通過修改已有的代碼來完成變化
通俗來講: 一個軟件產(chǎn)品在生命周期內(nèi)步绸,都會發(fā)生變化,既然變化是一個既定的事實(shí)吃媒,我們就應(yīng)該在設(shè)計的時候盡量適應(yīng)這些變化瓤介,以提高項目的穩(wěn)定性和靈活性吕喘。
一句話概括: 單一職責(zé)原則告訴我們實(shí)現(xiàn)類要職責(zé)單一;里氏替換原則告訴我們不要破壞繼承體系刑桑;依賴倒置原則告訴我們要面向接口編程兽泄;接口隔離原則告訴我們在設(shè)計接口的時候要精簡單一;迪米特法則告訴我們要降低耦合漾月。而開閉原則是總綱,他告訴我們要對擴(kuò)展開放胃珍,對修改關(guān)閉梁肿。
二、責(zé)任鏈模式
響應(yīng)鏈