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