SOLID 是面向?qū)ο笤O(shè)計(jì)重要原則的首字母縮寫(xiě).
當(dāng)我們?cè)O(shè)計(jì)類和模塊時(shí),遵守 SOLID 原則可以讓軟件更加健壯和穩(wěn)定。
單一職責(zé)原則(SRP:Single Responsibility Principle)
一個(gè)類有且只有一個(gè)職責(zé)。因?yàn)轭惥拖袢萜饕粯?,它能添加任意?shù)量的屬性、方法等。
但實(shí)現(xiàn)太多,這個(gè)類就會(huì)變得笨重。任意小的改變都將導(dǎo)致這個(gè)類的變化。當(dāng)你改了這個(gè)類,你將需要重新測(cè)試一遍。
如果遵守 SRP,每一個(gè)類將負(fù)責(zé)單一的問(wèn)題、任務(wù)或者它關(guān)注的點(diǎn),你的類將變得簡(jiǎn)潔和靈活。當(dāng)發(fā)生改變, 只需要修改相應(yīng)的類,只有這個(gè)類需要再次測(cè)試。SRP 核心是把整個(gè)問(wèn)題分為小部分,并且每個(gè)小部分都將通過(guò)一個(gè)單獨(dú)的類負(fù)責(zé)。
開(kāi)放封閉原則(OCP:Open Closed Principle)
一個(gè)類應(yīng)該對(duì)擴(kuò)展開(kāi)放,對(duì)修改關(guān)閉。一旦你創(chuàng)建了一個(gè)類并且開(kāi)始使用它,你不應(yīng)該修改它。因?yàn)槿绻淖兯?,很可能你的改變?huì)引發(fā)程序的崩潰。
如果你需要一些額外功能,你應(yīng)該擴(kuò)展這個(gè)類而不是修改它,比如說(shuō)創(chuàng)建子類,或者使用面向接口編程,定義一些接口,用新類去實(shí)現(xiàn)接口.
里氏替換原則(LSP:Liskov Substitution Principle)
所有基類出現(xiàn)的地方,都應(yīng)該可以透明的使用子類對(duì)象,且不會(huì)影響程序的正確性。
當(dāng)通過(guò)繼承實(shí)現(xiàn)多態(tài)行為,如果子類沒(méi)有遵守LSP,可能會(huì)讓程序引發(fā)異常。所以謹(jǐn)慎使用繼承,只有確定是“is-a”的關(guān)系時(shí)才使用繼承。
迪米特法則( LOD:Law of Demeter)
如果兩個(gè)對(duì)象無(wú)須直接通信,那么就不應(yīng)當(dāng)發(fā)生直接的相互調(diào)用,可以通過(guò)第三方轉(zhuǎn)發(fā)該調(diào)用。
其目的是降低類之間的耦合度,提高模塊的相對(duì)獨(dú)立性。
接口分離原則(ISP:Interface Segregation Principle)
一個(gè)接口應(yīng)該擁有盡可能少的行為,它是精簡(jiǎn)的,也是單一的。
類不應(yīng)該被迫依賴不需要的方法,也就是類不應(yīng)該依賴不需要的接口函數(shù),
依賴倒置原則(DIP:Dependence Inversion Principle)
高層模塊不應(yīng)該依賴低層模塊,相反,應(yīng)該依賴抽象類或者接口。這意味著你不應(yīng)該在高層模塊中使用具體的低層模塊。因?yàn)檫@樣的話,高層模塊變得緊耦合低層模塊。
如果明天,你改變了低層模塊,那么高層模塊也會(huì)被修改。根據(jù)DIP原則,高層模塊應(yīng)該依賴抽象(以抽象類或者接口的形式),低層模塊也是如此。通過(guò)面向接口(抽象類)編程,緊耦合被移除。
那么什么是高層模塊,什么是低層模塊呢?通常情況,我們會(huì)在一個(gè)類(高層模塊)的內(nèi)部實(shí)例化它依賴的對(duì)象(低層模塊),這樣勢(shì)必造成兩者的緊耦合,任何依賴對(duì)象的改變都將引起類的改變。