成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

淺談三層結(jié)構(gòu)與MVC模式的區(qū)別

開發(fā) 后端 架構(gòu)
本文將用通俗的語言,為大家介紹三層結(jié)構(gòu)與MVC模式的區(qū)別。其中還以80后最常見的玩具卡帶式游戲機(jī)作為比喻,形象而生動(dòng)。希望能幫助大家理解二者的區(qū)別。

51CTO編輯推薦《ASP.NET MVC框架視頻教程

有朋友談到三層與MVC的區(qū)別,以前也有人拋出這個(gè)問題,本人對(duì)來公司面試的朋友也偶樂會(huì)提這方面的問題。

那么我也來講講我對(duì)這兩者的理解吧。

首先對(duì)這個(gè)題目,本身是存在問題的,“XX結(jié)構(gòu)”與“XX模式”的區(qū)別?請(qǐng)問中國社會(huì)制度與美國人生活方式有什么區(qū)別?

這兩者本身講的是不同方向與角度的問題,在實(shí)際應(yīng)用中他們的確存在一些相似的特點(diǎn),在很多書籍中也沒有深入講解,以致于造成困惑,為了更好的理解他們,姑且來說說區(qū)別吧。

首先N層結(jié)構(gòu)是一種軟件抽象的層次結(jié)構(gòu),是對(duì)復(fù)雜軟件的一種縱向切分,每一層次中完成同一類型的操作,以便將各種代碼以其完成的使命作為依據(jù)來分割,以將低軟件的復(fù)雜度,提高其可維護(hù)性。一般來說,層次之間是向下依賴的,下層代碼未確定其接口(契約)前,上層代碼是無法開發(fā)的,下層代碼接口(契約)的變化將使上層的代碼一起變化。三層結(jié)構(gòu)是N層結(jié)構(gòu)的一種,是人產(chǎn)在長時(shí)間使用中得出來的一種應(yīng)用場合廣泛的N層結(jié)構(gòu),被當(dāng)作一種典型的軟件層次結(jié)構(gòu)而廣為流傳甚至寫入教科書。

MVC模式是一種復(fù)合設(shè)計(jì)模式,一種在特定場合用于解決某種實(shí)際問題來得出的可以反復(fù)實(shí)踐的解決方案。巧合的是他也有三個(gè)事物組成,于是乎人們就有了一種想當(dāng)然的對(duì)應(yīng)關(guān)系:展示層-View;業(yè)務(wù)邏輯層-Control;持久層-Model。首先MVC中的三個(gè)事物之間并不存在明顯的層次結(jié)構(gòu),沒有明顯的向下依賴關(guān)系,相反的,View和Model往往是比較獨(dú)立的,而Control是連接兩者的橋梁,他們更像是橫向的切分。這樣一來就出現(xiàn)一個(gè)結(jié)果,MVC中每個(gè)塊都是可以獨(dú)立測試的,而三層結(jié)構(gòu)中,上層模塊的運(yùn)行測試勢(shì)必要提供下層代碼或者提供相同接口的樁。相對(duì)來說,MVC復(fù)雜得多,但是結(jié)構(gòu)更清晰,耦合性更低。

另外,MVC中每一塊內(nèi)部特別是Model內(nèi)部經(jīng)常被設(shè)計(jì)為多層的。在我認(rèn)為的一個(gè)良好的MVC模式構(gòu)建的結(jié)構(gòu)中,Control是核心,小且較為穩(wěn)定的,可以作為一個(gè)核心框架來提供,有擴(kuò)展點(diǎn),但基本上可以簡單配置不需要任何代碼就可以運(yùn)行。而View則可能是一套或多種可選擇的視圖引擎,決定了軟件展示給用于的界面,使用時(shí)的主要工作量在于擴(kuò)展點(diǎn)以及根據(jù)需要而數(shù)量不同的視圖模板。Model則是業(yè)務(wù)提供者,決定了軟件提供的功能,其內(nèi)部可能是一些普通的類或者是實(shí)現(xiàn)了某些接口的類,在這一塊當(dāng)中可能根據(jù)業(yè)務(wù)的不同而色彩繽紛,對(duì)于復(fù)雜的軟件可能會(huì)分成很多層,如業(yè)務(wù)邏輯層、業(yè)務(wù)提供層、系統(tǒng)提供層、數(shù)據(jù)提供層、數(shù)據(jù)訪問層等。

我經(jīng)常用于比喻MVC的例子是小時(shí)候玩的那種卡帶式游戲機(jī),Control是主機(jī),一般來說我買一個(gè)主機(jī)就行了,只要他不壞,他就能一直讓我玩這一類的游戲。View則是電視機(jī)和游戲手柄,電視機(jī)可以獨(dú)立工作,他不管輸入的是電視信號(hào)、影碟機(jī)信號(hào)還是游戲機(jī)信號(hào),他只管顯示,而且他決定了我們看到的效果是怎么樣的,如果我想要個(gè)尺寸更大的或者彩色的顯示效果,我只需要買個(gè)相應(yīng)的電視機(jī)就行了,手柄也是可以換的,要遙桿還是帶震動(dòng)的。Model則是游戲卡帶,他絕定了我玩的是什么游戲,是魂斗羅還是超級(jí)瑪莉,而且游戲機(jī)主機(jī)和電視機(jī)生產(chǎn)廠家永遠(yuǎn)也不知道在上面有可能會(huì)運(yùn)行什么樣的游戲。卡帶中可能會(huì)有游戲代碼和存儲(chǔ)單元,都根據(jù)游戲的需要而設(shè)計(jì)。

有朋友提到游戲主機(jī)提供的卡帶插槽的接口,在設(shè)計(jì)中,有時(shí)也由Control提供一組接口,以用于Model或View的實(shí)現(xiàn),這樣就形成了依賴。一般來說這樣設(shè)計(jì)也沒有太大的問題,只是會(huì)提高模塊間的耦合度,也會(huì)帶來一些侵入性。為了更***,可以不用接口來提供契約,可以用配置信息(或稱元數(shù)據(jù)信息)+反射來提供契約,那么這個(gè)類接口就可以退化到只要符合CLS就可以了,也就是普通的類,就像現(xiàn)在的計(jì)算機(jī)接口廣泛采用USB,無論是U盤、打印機(jī)、掃描儀或者是加密狗,他們都是普通的USB設(shè)備而已。

提到USB有一個(gè)題外話,模塊的可插拔性設(shè)計(jì)甚至是熱插拔設(shè)計(jì),系統(tǒng)可以在不停止運(yùn)行的情況下動(dòng)態(tài)的掛載或移除模塊,動(dòng)態(tài)掛載模塊需要系統(tǒng)能夠自動(dòng)發(fā)現(xiàn)新模塊并根據(jù)自描述的信息進(jìn)行自動(dòng)配置,移除可能情況更復(fù)雜一點(diǎn),需要“安全刪除硬件”類似的功能。

在設(shè)計(jì)廣泛重用的框架時(shí)會(huì)考慮多種情況以達(dá)到更大的適應(yīng)性,一般項(xiàng)目中應(yīng)用MVC模式可以較為隨意。

【編輯推薦】

  1. 簡單理解ASP.NET MVC基本知識(shí)
  2. 詳解.Net環(huán)境下基于Ajax的MVC方案
  3. 實(shí)戰(zhàn)ASP.NET MVC幫助理解Routing
責(zé)任編輯:彭凡 來源: cnblogs
相關(guān)推薦

2019-07-26 08:39:29

JavaWebMVC

2012-02-07 10:40:13

MVCJava

2009-07-30 13:30:56

ASP.NET開發(fā)模式

2009-04-21 11:27:52

MVCJSPJDBC

2009-07-28 17:25:14

ASP.NET三層結(jié)構(gòu)

2009-07-28 15:08:50

MVC三層架構(gòu)實(shí)例

2009-04-30 15:56:50

三層架構(gòu)MVCMVP

2009-09-23 17:29:54

三層框架

2018-10-29 14:54:12

交換機(jī)路由器網(wǎng)絡(luò)

2017-06-12 13:18:51

數(shù)據(jù)報(bào)表計(jì)算

2009-07-30 13:07:49

ASP.NET中的三層

2014-10-11 17:06:07

交換機(jī)

2018-10-31 09:02:36

交換機(jī)三層二層

2010-01-11 17:35:07

二層交換機(jī)三層交換機(jī)

2012-04-19 10:05:27

2011-04-19 13:53:41

三層架構(gòu)

2010-01-27 16:42:14

三層交換機(jī)

2010-03-17 17:11:20

三層交換機(jī)

2012-07-16 10:19:02

MongoDB

2009-08-26 18:20:42

三層架構(gòu)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 久久久久久国产精品 | 91久久精品日日躁夜夜躁国产 | 国产精品永久免费 | 国产片侵犯亲女视频播放 | 精品久久香蕉国产线看观看亚洲 | 久久精品色欧美aⅴ一区二区 | 亚洲毛片 | 国产午夜精品久久 | 欧美v免费 | 精品视频一二区 | 中文亚洲视频 | 国产精品亚洲片在线播放 | 亚洲欧美视频一区 | 国产一区在线免费观看 | 国产成人精品一区二区三 | 精品国产一级 | 黑人成人网 | www.日韩系列 | 1000部精品久久久久久久久 | 国产精品免费在线 | av一区二区三区 | 三级黄色片在线播放 | 福利电影在线 | 午夜日韩精品 | 国产一区成人 | 国产超碰人人爽人人做人人爱 | 久久久久亚洲av毛片大全 | 偷拍亚洲色图 | 一区二区三区精品视频 | 爱爱免费视频网站 | 91久久精品日日躁夜夜躁欧美 | 国产成人精品a视频一区www | 97精品久久 | 国产视频精品区 | 国产一区二区三区网站 | 国产精品永久免费 | 在线免费毛片 | 日本不卡一区二区三区在线观看 | 亚洲精品国产综合区久久久久久久 | 99热成人在线 | 国产精品一区在线观看你懂的 |