架構(gòu)、框架、設(shè)計模式之間的關(guān)系簡述
一、軟件體系結(jié)構(gòu)和框架的定義
軟件體系結(jié)構(gòu)的英文單詞是“architecture”. Architecture的基本詞義是建筑、建筑學、建筑風格。
軟件體系結(jié)構(gòu)雖然根植于軟件工程,但還處于一個研究發(fā)展的階段,迄今為止還沒有一個為大家所公認的定義。
《設(shè)計模式》中對框架的定義是框架就是一組相互協(xié)作的類,對于特定的一類軟件,框架構(gòu)成了一種可重用的設(shè)計。
軟件框架是項目軟件開發(fā)過程中提取特定領(lǐng)域軟件的共性部分形成的體系結(jié)構(gòu),不同領(lǐng)域的軟件項目有著不同的框架類型??蚣艿淖饔迷谟冢河捎谔崛×颂囟I(lǐng)域軟件的共性部分,因此在此領(lǐng)域內(nèi)新項目的開發(fā)過程中代碼不需要從頭編寫,只需要在框架的基礎(chǔ)上進行一些開發(fā)和調(diào)整便可滿足要求;對于開發(fā)過程而言,這樣做會提高軟件的質(zhì)量,降低成本,縮短開發(fā)時間,使開發(fā)越做越輕松,效益越做越好,形成一種良性循環(huán)。
框架不是現(xiàn)成可用的應(yīng)用系統(tǒng)。是一個半成品,需要后來的開發(fā)人員進行二次開發(fā),實現(xiàn)具體功能的應(yīng)用系統(tǒng)。框架不是“平臺”,平臺概念比較模糊可以是一種操作系統(tǒng),一種應(yīng)用服務(wù)器,一種數(shù)據(jù)庫軟件,一種通訊中間件等地那個,因此平臺在應(yīng)用平臺主要指提供特定服務(wù)的系統(tǒng)軟件,而框架更側(cè)重了設(shè)計,開發(fā)過程,或者可以說,框架通過調(diào)用平臺提供的服務(wù)而起的作用。
框架不是工具包或者類庫,調(diào)用API并不就是在使用框架開發(fā),緊緊使用API是,開發(fā)者完成系統(tǒng)的主題部分,并不時地調(diào)用類庫實現(xiàn)特定任務(wù)。而框架構(gòu)成了通用的、具有一般性的系統(tǒng)主體部分,二次開發(fā)人員只是像做填空一樣,根據(jù)具體業(yè)務(wù),完成特定應(yīng)用系統(tǒng)中與眾不同的特殊部分。
二、框架與架構(gòu)之間的關(guān)系
框架不是構(gòu)架(即軟件體系機構(gòu))。體系結(jié)構(gòu)確定了系統(tǒng)整體結(jié)構(gòu)、層次劃分,不同部分之間的協(xié)作等設(shè)計考慮??蚣鼙燃軜?gòu)更具體。更偏重于技術(shù)涉嫌。確定框架后,軟件體系結(jié)構(gòu)也隨之確定,而對于同一軟件體系結(jié)構(gòu)(比如Web開發(fā)中的MVC),可以通過多種框架來實現(xiàn)。
三、框架與設(shè)計模式之間的關(guān)系
設(shè)計模式和框架在軟件設(shè)計中是兩個不同的研究領(lǐng)域。設(shè)計模式研究的是一個設(shè)計問題的解決方法,一個模式可應(yīng)用于不同的框架和被不同的語言所實現(xiàn);而框架則是一個應(yīng)用的體系結(jié)構(gòu),是一種或多種設(shè)計模式和代碼的混合體雖然它們有所不同,但卻共同致力于使人們的設(shè)計可以被重用,在思想上存在著統(tǒng)一性的特點,因而設(shè)計模式的思想可以在框架設(shè)計中進行應(yīng)用。
框架和設(shè)計模式存在著顯著的區(qū)別,主要表現(xiàn)在二者提供的內(nèi)容和致力應(yīng)用的領(lǐng)域。
1)、從應(yīng)用領(lǐng)域上分,框架給出的是整個應(yīng)用的體系結(jié)構(gòu);而設(shè)計模式則給出了單一設(shè)計問題的解決方案,并且這個方案可在不同的應(yīng)用程序或者框架中進行應(yīng)用。
2)、從內(nèi)容上分,設(shè)計模式僅是一個單純的設(shè)計,這個設(shè)計可被不同語言以不用方式來實現(xiàn);而框架則是設(shè)計和代碼的一個混合體,編程者可以用各種方式對框架進行擴展,進而形成完整的不同的應(yīng)用。
3)、以第二條為基礎(chǔ),可以得出設(shè)計模式比框架更容易移植:框架一旦設(shè)計成形,雖然還沒有構(gòu)成完整的一個應(yīng)用,但是以其為基礎(chǔ)進行應(yīng)用的開發(fā)顯然要受制于框架的實現(xiàn)環(huán)境;而設(shè)計模式是與語言無關(guān)的,所以可以在更廣泛的異構(gòu)環(huán)境中進行應(yīng)用。
總之,框架是軟件,而設(shè)計模式是軟件的知識體,提升框架的設(shè)計水平。
【編輯推薦】