Source: http://book.csdn.net/bookfiles/383/10038314337.shtml
“依賴”是和“變化”緊密聯(lián)系在一起的概念。由于依賴關(guān)系的存在,變化在某處發(fā)生時,影響會波及開去,造成很多修改工作,這就是依賴的危害。可以說,變化是始作俑者,依賴是助紂為虐。
我們可以不去擁抱變化嗎?不可以。未來將越來越不可預(yù)測,這是新經(jīng)濟(jì)最具挑戰(zhàn)性的方面之一。商務(wù)和技術(shù)上的瞬息萬變會產(chǎn)生變化,這既可以看作要防范的威脅,也可以看作應(yīng)該歡迎的機(jī)遇。
既然變化不可避免,我們所能做的就是處理好依賴關(guān)系,將變化造成的影響的波及范圍盡量減小。
下面總結(jié)一下“面向?qū)ο笤O(shè)計5大原則”和良性依賴原則在應(yīng)付變化方面的作用。
單一職責(zé)原則(Single-Responsibility Principle)。“對一個類而言,應(yīng)該僅有一個引起它變化的原因”。本原則是我們非常熟悉地“高內(nèi)聚性原則”的引申,但是通過將“職責(zé)”極具創(chuàng)意地定義為“變化的原因”,使得本原則極具可操作性,盡顯大師風(fēng)范。同時,本原則還揭示了內(nèi)聚性和耦合性是“一物兩面”的關(guān)系,為了降低耦合性,基本途徑就是提高內(nèi)聚性;如果一個類承擔(dān)的職責(zé)過多,那么這些職責(zé)就會相互依賴,一個職責(zé)的變化可能會影響另一個職責(zé)的履行。其實(shí)OOD的實(shí)質(zhì),就是合理地進(jìn)行類的職責(zé)分配。
開放封閉原則(Open-Closed Principle)。“軟件實(shí)體應(yīng)該是可以擴(kuò)展的,但是不可修改”。本原則緊緊圍繞變化展開,變化來臨時,如果不必改動軟件實(shí)體的源代碼,就能擴(kuò)充它的行為,那么這個軟件實(shí)體的設(shè)計就是滿足開放封閉原則的。如果我們預(yù)測到某種變化,或者某種變化發(fā)生了,我們應(yīng)當(dāng)創(chuàng)建抽象來隔離以后發(fā)生的同類變化。在Java中,這種抽象指抽象基類或接口;在C++中,這種抽象是指抽象基類或純抽象基類。當(dāng)然,沒有對所有情況都貼切的模型,我們必須對軟件實(shí)體應(yīng)該面對的變化做出選擇。
Liskov替換原則(Liskov-Substitution Principle)。“子類型必須能夠替換掉它們的基類型”。本原則和開放封閉原則關(guān)系密切,正是子類型的可替換性,才使得使用基類型的模塊無需修改就可擴(kuò)充。Liskov替換原則從基于契約的設(shè)計演化而來,契約通過為每個方法聲明“先驗(yàn)條件”和“后驗(yàn)條件”;定義子類時,必須遵守這些“先驗(yàn)條件”和“后驗(yàn)條件”。當(dāng)前,基于契約的設(shè)計發(fā)展勢頭正勁,對實(shí)現(xiàn)“軟件工廠”的“組裝生產(chǎn)”夢想是一個有力的支持。
依賴倒置原則(Dependency-Inversion Principle)。“抽象不應(yīng)依賴于細(xì)節(jié),細(xì)節(jié)應(yīng)該依賴于抽象”。本原則幾乎就是軟件設(shè)計的正本清源之道。因?yàn)槿私鉀Q問題的思考過程是先抽象后具體,從籠統(tǒng)到細(xì)節(jié)的,所以我們先生產(chǎn)出的勢必是抽象程度比較高的實(shí)體,而后才是更加細(xì)節(jié)化的實(shí)體。于是,“細(xì)節(jié)依賴于抽象”就意味著后來的依賴于先前的,這是自然而然的重用之道。而且,抽象的實(shí)體代表著籠而統(tǒng)之的認(rèn)識,人們總是比較容易正確認(rèn)識它們,而且它們本身也是不易變的,依賴于它們是安全的。依賴倒置原則適應(yīng)了人類認(rèn)識過程的規(guī)律,是面向?qū)ο笤O(shè)計的標(biāo)志所在。
接口隔離原則(Interface-Segregation Principle)。“多個專用接口優(yōu)于一個單一的通用接口”。本原則是單一職責(zé)原則用于接口設(shè)計的自然結(jié)果。一個接口應(yīng)該保證,實(shí)現(xiàn)該接口的實(shí)例對象可以只呈現(xiàn)為單一的角色;這樣,當(dāng)某個客戶程序的要求發(fā)生變化,而迫使接口發(fā)生改變時,影響到其他客戶程序的可能性最小。
良性依賴原則。“不會在實(shí)際中造成危害的依賴關(guān)系,都是良性依賴”。通過分析不難發(fā)現(xiàn),本原則的核心思想是“務(wù)實(shí)”,很好地揭示了極限編程(Extreme Programming)中“簡單設(shè)計”和“重構(gòu)”的理論基礎(chǔ)。本原則可以幫助我們抵御“面向?qū)ο笤O(shè)計5大原則”以及設(shè)計模式的誘惑,以免陷入過度設(shè)計(Over-engineering)的尷尬境地,帶來不必要的復(fù)雜性。
本博客為學(xué)習(xí)交流用,凡未注明引用的均為本人作品,轉(zhuǎn)載請注明出處,如有版權(quán)問題請及時通知。由于博客時間倉促,錯誤之處敬請諒解,有任何意見可給我留言,愿共同學(xué)習(xí)進(jìn)步。