對(duì)于面向?qū)ο筌浖到y(tǒng)的設(shè)計(jì)而言,在支持可維護(hù)性的同時(shí),提高系統(tǒng)的可復(fù)用性是一個(gè)至關(guān)重要的問(wèn)題,如何同時(shí)提高一個(gè)軟件系統(tǒng)的可維護(hù)性和可復(fù)用性是面向?qū)ο笤O(shè)計(jì)需要解決的核心問(wèn)題之一。在面向?qū)ο笤O(shè)計(jì)中,可維護(hù)性的復(fù)用是以設(shè)計(jì)原則為基礎(chǔ)的。每一個(gè)原則都蘊(yùn)含一些面向?qū)ο笤O(shè)計(jì)的思想,可以從不同的角度提升一個(gè)軟件結(jié)構(gòu)的設(shè)計(jì)水平。
面向?qū)ο笤O(shè)計(jì)原則為支持可維護(hù)性可復(fù)用性而誕生,這些原則蘊(yùn)含在很多設(shè)計(jì)模式中,它們是從許多設(shè)計(jì)方案中總結(jié)出的指導(dǎo)性原則。面向?qū)ο笤O(shè)計(jì)原則也是我們用于評(píng)價(jià)一個(gè)設(shè)計(jì)模式的使用效果的重要指標(biāo)之一,在設(shè)計(jì)模式的學(xué)習(xí)中,大家經(jīng)常會(huì)看到諸如“XXX模式符合XXX原則”、“XXX模式違反了XXX原則”這樣的語(yǔ)句。
最常見(jiàn)的7種面向?qū)ο笤O(shè)計(jì)原則如下表所示:
| 設(shè)計(jì)原則名稱 | 定義 |
|---|---|
| 開閉原則(總原則) | 軟件實(shí)體應(yīng)對(duì)擴(kuò)展開放,而對(duì)修改關(guān)閉 |
| 單一職責(zé)原則 | 一個(gè)類只負(fù)責(zé)一個(gè)功能領(lǐng)域中的相應(yīng)職責(zé) |
| 里氏替換原則 | 所有引用基類對(duì)象的地方能夠透明地使用其子類的對(duì)象 |
| 依賴倒置原則 | 抽象不應(yīng)該依賴于細(xì)節(jié),細(xì)節(jié)應(yīng)該依賴于抽象 |
| 接口隔離原則 | 使用多個(gè)專門的接口,而不使用單一的總接口 |
| 合成復(fù)用原則 | 盡量使用對(duì)象組合,而不是繼承來(lái)達(dá)到復(fù)用的目的 |
| 迪米特法則 | 一個(gè)軟件實(shí)體應(yīng)當(dāng)盡可能少地與其他實(shí)體發(fā)生相互作用 |