常用的面向?qū)ο笤O(shè)計(jì)原則包括7個,分別是單一職責(zé)原則、開閉原則、里氏代換原則、依賴倒轉(zhuǎn)原則、接口隔離原則、合成復(fù)用原則和迪米特原則。
面向?qū)ο笤O(shè)計(jì)的目標(biāo)之一在于支持可維持性復(fù)用,一方面需要實(shí)現(xiàn)設(shè)計(jì)方案或者源代碼的復(fù)用,另一方面要確保系統(tǒng)能夠易于擴(kuò)展和修改,具有較好的靈活性。
一.單一職責(zé)原則
Single Responsibility Principle,SRP
一個類只負(fù)責(zé)一個功能領(lǐng)域中的相應(yīng)職責(zé)。或者說,一個類,應(yīng)該只有一個引起它變化的原因。
二.開閉原則
Open-Closed Principle,OCP
一個軟件實(shí)體應(yīng)當(dāng)對擴(kuò)展開放,對修改關(guān)閉。即軟件實(shí)體應(yīng)盡量在不修改原有代碼的情況下進(jìn)行擴(kuò)展。
在定義中,軟件實(shí)體可以指一個軟件模塊、一個由多個類組成的局部結(jié)構(gòu)或一個獨(dú)立的類。
為了滿足開閉原則,需要對系統(tǒng)進(jìn)行抽象化設(shè)計(jì),抽象化是開閉原則的關(guān)鍵。
三.里氏代換原則
Liskov Substitution Principle,LSP
所有引用基類(父類)的地方必須能透明的使用其子類的對象。
里氏代換原則表明,在軟件中將一個基類對象替換成它的子類對象,程序?qū)⒉粫a(chǎn)生任何錯誤和異常,反過來則不成立。
里氏代換原則是實(shí)現(xiàn)開閉原則的重要方式之一,在運(yùn)用里氏代換原則時,應(yīng)該將父類設(shè)計(jì)為抽象類或者接口,讓子類繼承父類或?qū)崿F(xiàn)父接口,并實(shí)現(xiàn)在父類中聲明的方法,運(yùn)行時,子類實(shí)例替換父類實(shí)例,可以很方便的擴(kuò)展系統(tǒng)的功能,無須修改原有子類的代碼,增加新的功能可以通過增加一個新的子類來實(shí)現(xiàn)。
四.依賴倒轉(zhuǎn)原則
Dependency Inversion Principle,DIP
如果說開閉原則是面向?qū)ο笤O(shè)計(jì)的目標(biāo)的話,那么依賴倒轉(zhuǎn)原則就是面向?qū)ο笤O(shè)計(jì)的主要實(shí)現(xiàn)機(jī)制之一,它是系統(tǒng)抽象化的具體實(shí)現(xiàn)。
抽象不應(yīng)該依賴于細(xì)節(jié),細(xì)節(jié)應(yīng)當(dāng)依賴于抽象。換句話說,要針對接口編程,而不是針對實(shí)現(xiàn)編程。
依賴倒轉(zhuǎn)原則要求在程序代碼中傳遞傳遞參數(shù)時或者關(guān)聯(lián)關(guān)系中,盡量引用層次高的抽象層類,即使用接口和抽象類進(jìn)行變量類型聲明、參數(shù)類型聲明、方法返回類型聲明,以及數(shù)據(jù)類型的轉(zhuǎn)換等,而不要使用具體類來做這些事情。
在實(shí)現(xiàn)依賴倒轉(zhuǎn)原則時,需要針對抽象層編程,而將具體類的對象通過依賴注入的方式注入到其他對象中。依賴注入是指當(dāng)一個對象要與其他對象發(fā)生依賴關(guān)系時,通過抽象來注入所依賴的對象。
常用的注入方式有三種:
- 構(gòu)造注入:通過構(gòu)造函數(shù)來傳入具體類的對象。
- 設(shè)置注入:通過setter方法來傳入具體類的對象。
- 接口注入:通過實(shí)現(xiàn)在接口中聲明的業(yè)務(wù)方法來傳入具體類的對象。
五.接口隔離原則
Interface Segregation Principle,ISP
使用多個專門的接口,而不使用單一的總接口,即客戶端不應(yīng)該依賴那些他不需要的接口。
這里的接口有兩種不同的含義:一種是指一個類型所具有的方法特征的集合,僅僅是一種邏輯上的抽象;另一種是指某種語言具體的接口定義,有嚴(yán)格的定義和結(jié)構(gòu),比如Java語言中的interface。
六.合成復(fù)用原則
Composite Reuse Principle,CRP
盡量使用對象組合,而不是繼承來達(dá)到復(fù)用的目的。
七.迪米特法則
Law of Demeter,LOD
一個軟件實(shí)體應(yīng)當(dāng)盡可能少地與其他實(shí)體發(fā)生相互作用。