SOLID 是面向?qū)ο笤O(shè)計重要原則的首字母縮寫.
當(dāng)我們設(shè)計類和模塊時希坚,遵守 SOLID 原則可以讓軟件更加健壯和穩(wěn)定。
單一職責(zé)原則(SRP:Single Responsibility Principle)
一個類有且只有一個職責(zé)好港。因為類就像容器一樣媒怯,它能添加任意數(shù)量的屬性鸽嫂、方法等纵装。
但實現(xiàn)太多,這個類就會變得笨重据某。任意小的改變都將導(dǎo)致這個類的變化橡娄。當(dāng)你改了這個類,你將需要重新測試一遍癣籽。
如果遵守 SRP挽唉,每一個類將負(fù)責(zé)單一的問題、任務(wù)或者它關(guān)注的點,你的類將變得簡潔和靈活筷狼。當(dāng)發(fā)生改變, 只需要修改相應(yīng)的類瓶籽,只有這個類需要再次測試。SRP 核心是把整個問題分為小部分埂材,并且每個小部分都將通過一個單獨的類負(fù)責(zé)塑顺。
開放封閉原則(OCP:Open Closed Principle)
一個類應(yīng)該對擴(kuò)展開放,對修改關(guān)閉楞遏。一旦你創(chuàng)建了一個類并且開始使用它茬暇,你不應(yīng)該修改它首昔。因為如果改變它寡喝,很可能你的改變會引發(fā)程序的崩潰糙俗。
如果你需要一些額外功能,你應(yīng)該擴(kuò)展這個類而不是修改它,比如說創(chuàng)建子類,或者使用面向接口編程,定義一些接口预鬓,用新類去實現(xiàn)接口.
里氏替換原則(LSP:Liskov Substitution Principle)
所有基類出現(xiàn)的地方巧骚,都應(yīng)該可以透明的使用子類對象,且不會影響程序的正確性格二。
當(dāng)通過繼承實現(xiàn)多態(tài)行為劈彪,如果子類沒有遵守LSP,可能會讓程序引發(fā)異常顶猜。所以謹(jǐn)慎使用繼承沧奴,只有確定是“is-a”的關(guān)系時才使用繼承。
迪米特法則( LOD:Law of Demeter)
如果兩個對象無須直接通信长窄,那么就不應(yīng)當(dāng)發(fā)生直接的相互調(diào)用滔吠,可以通過第三方轉(zhuǎn)發(fā)該調(diào)用。
其目的是降低類之間的耦合度挠日,提高模塊的相對獨立性疮绷。
接口分離原則(ISP:Interface Segregation Principle)
一個接口應(yīng)該擁有盡可能少的行為,它是精簡的嚣潜,也是單一的冬骚。
類不應(yīng)該被迫依賴不需要的方法,也就是類不應(yīng)該依賴不需要的接口函數(shù),
依賴倒置原則(DIP:Dependence Inversion Principle)
高層模塊不應(yīng)該依賴低層模塊懂算,相反只冻,應(yīng)該依賴抽象類或者接口。這意味著你不應(yīng)該在高層模塊中使用具體的低層模塊计技。因為這樣的話喜德,高層模塊變得緊耦合低層模塊。
如果明天酸役,你改變了低層模塊住诸,那么高層模塊也會被修改。根據(jù)DIP原則涣澡,高層模塊應(yīng)該依賴抽象(以抽象類或者接口的形式)贱呐,低層模塊也是如此。通過面向接口(抽象類)編程入桂,緊耦合被移除奄薇。
那么什么是高層模塊,什么是低層模塊呢抗愁?通常情況馁蒂,我們會在一個類(高層模塊)的內(nèi)部實例化它依賴的對象(低層模塊)呵晚,這樣勢必造成兩者的緊耦合,任何依賴對象的改變都將引起類的改變沫屡。