淺談三層結(jié)構(gòu)與MVC模式的區(qū)別
51CTO編輯推薦《ASP.NET MVC框架視頻教程》
有朋友談到三層與MVC的區(qū)別,以前也有人拋出這個問題,本人對來公司面試的朋友也偶樂會提這方面的問題。
那么我也來講講我對這兩者的理解吧。
首先對這個題目,本身是存在問題的,“XX結(jié)構(gòu)”與“XX模式”的區(qū)別?請問中國社會制度與美國人生活方式有什么區(qū)別?
這兩者本身講的是不同方向與角度的問題,在實(shí)際應(yīng)用中他們的確存在一些相似的特點(diǎn),在很多書籍中也沒有深入講解,以致于造成困惑,為了更好的理解他們,姑且來說說區(qū)別吧。
首先N層結(jié)構(gòu)是一種軟件抽象的層次結(jié)構(gòu),是對復(fù)雜軟件的一種縱向切分,每一層次中完成同一類型的操作,以便將各種代碼以其完成的使命作為依據(jù)來分割,以將低軟件的復(fù)雜度,提高其可維護(hù)性。一般來說,層次之間是向下依賴的,下層代碼未確定其接口(契約)前,上層代碼是無法開發(fā)的,下層代碼接口(契約)的變化將使上層的代碼一起變化。三層結(jié)構(gòu)是N層結(jié)構(gòu)的一種,是人產(chǎn)在長時間使用中得出來的一種應(yīng)用場合廣泛的N層結(jié)構(gòu),被當(dāng)作一種典型的軟件層次結(jié)構(gòu)而廣為流傳甚至寫入教科書。
MVC模式是一種復(fù)合設(shè)計模式,一種在特定場合用于解決某種實(shí)際問題來得出的可以反復(fù)實(shí)踐的解決方案。巧合的是他也有三個事物組成,于是乎人們就有了一種想當(dāng)然的對應(yīng)關(guān)系:展示層-View;業(yè)務(wù)邏輯層-Control;持久層-Model。首先MVC中的三個事物之間并不存在明顯的層次結(jié)構(gòu),沒有明顯的向下依賴關(guān)系,相反的,View和Model往往是比較獨(dú)立的,而Control是連接兩者的橋梁,他們更像是橫向的切分。這樣一來就出現(xiàn)一個結(jié)果,MVC中每個塊都是可以獨(dú)立測試的,而三層結(jié)構(gòu)中,上層模塊的運(yùn)行測試勢必要提供下層代碼或者提供相同接口的樁。相對來說,MVC復(fù)雜得多,但是結(jié)構(gòu)更清晰,耦合性更低。
另外,MVC中每一塊內(nèi)部特別是Model內(nèi)部經(jīng)常被設(shè)計為多層的。在我認(rèn)為的一個良好的MVC模式構(gòu)建的結(jié)構(gòu)中,Control是核心,小且較為穩(wěn)定的,可以作為一個核心框架來提供,有擴(kuò)展點(diǎn),但基本上可以簡單配置不需要任何代碼就可以運(yùn)行。而View則可能是一套或多種可選擇的視圖引擎,決定了軟件展示給用于的界面,使用時的主要工作量在于擴(kuò)展點(diǎn)以及根據(jù)需要而數(shù)量不同的視圖模板。Model則是業(yè)務(wù)提供者,決定了軟件提供的功能,其內(nèi)部可能是一些普通的類或者是實(shí)現(xiàn)了某些接口的類,在這一塊當(dāng)中可能根據(jù)業(yè)務(wù)的不同而色彩繽紛,對于復(fù)雜的軟件可能會分成很多層,如業(yè)務(wù)邏輯層、業(yè)務(wù)提供層、系統(tǒng)提供層、數(shù)據(jù)提供層、數(shù)據(jù)訪問層等。
我經(jīng)常用于比喻MVC的例子是小時候玩的那種卡帶式游戲機(jī),Control是主機(jī),一般來說我買一個主機(jī)就行了,只要他不壞,他就能一直讓我玩這一類的游戲。View則是電視機(jī)和游戲手柄,電視機(jī)可以獨(dú)立工作,他不管輸入的是電視信號、影碟機(jī)信號還是游戲機(jī)信號,他只管顯示,而且他決定了我們看到的效果是怎么樣的,如果我想要個尺寸更大的或者彩色的顯示效果,我只需要買個相應(yīng)的電視機(jī)就行了,手柄也是可以換的,要遙桿還是帶震動的。Model則是游戲卡帶,他絕定了我玩的是什么游戲,是魂斗羅還是超級瑪莉,而且游戲機(jī)主機(jī)和電視機(jī)生產(chǎn)廠家永遠(yuǎn)也不知道在上面有可能會運(yùn)行什么樣的游戲??◣е锌赡軙杏螒虼a和存儲單元,都根據(jù)游戲的需要而設(shè)計。
有朋友提到游戲主機(jī)提供的卡帶插槽的接口,在設(shè)計中,有時也由Control提供一組接口,以用于Model或View的實(shí)現(xiàn),這樣就形成了依賴。一般來說這樣設(shè)計也沒有太大的問題,只是會提高模塊間的耦合度,也會帶來一些侵入性。為了更***,可以不用接口來提供契約,可以用配置信息(或稱元數(shù)據(jù)信息)+反射來提供契約,那么這個類接口就可以退化到只要符合CLS就可以了,也就是普通的類,就像現(xiàn)在的計算機(jī)接口廣泛采用USB,無論是U盤、打印機(jī)、掃描儀或者是加密狗,他們都是普通的USB設(shè)備而已。
提到USB有一個題外話,模塊的可插拔性設(shè)計甚至是熱插拔設(shè)計,系統(tǒng)可以在不停止運(yùn)行的情況下動態(tài)的掛載或移除模塊,動態(tài)掛載模塊需要系統(tǒng)能夠自動發(fā)現(xiàn)新模塊并根據(jù)自描述的信息進(jìn)行自動配置,移除可能情況更復(fù)雜一點(diǎn),需要“安全刪除硬件”類似的功能。
在設(shè)計廣泛重用的框架時會考慮多種情況以達(dá)到更大的適應(yīng)性,一般項(xiàng)目中應(yīng)用MVC模式可以較為隨意。
【編輯推薦】