MVC與三層架構(gòu)到底有什么聯(lián)系和區(qū)別

MVC和三層架構(gòu)望艺,是不一樣的苛秕。

三層架構(gòu)中,DAL(數(shù)據(jù)訪(fǎng)問(wèn)層)找默、BLL(業(yè)務(wù)邏輯層)艇劫、WEB層各司其職,意在職責(zé)分離惩激。

MVC是?Model-View-Controller店煞,嚴(yán)格說(shuō)這三個(gè)加起來(lái)以后才是三層架構(gòu)中的WEB層,也就是說(shuō)风钻,MVC把三層架構(gòu)中的WEB層再度進(jìn)行了分化顷蟀,分成了控制器、視圖骡技、實(shí)體三個(gè)部分鸣个,控制器完成頁(yè)面邏輯羞反,通過(guò)實(shí)體來(lái)與界面層完成通話(huà);而C層直接與三層中的BLL進(jìn)行對(duì)話(huà)囤萤。

所以昼窗,?.net的三層結(jié)構(gòu)中,并沒(méi)有action這個(gè)概念涛舍。

asp.netmvc?是微軟新發(fā)布的一種網(wǎng)站開(kāi)發(fā)架構(gòu)澄惊。為了解決傳統(tǒng)asp.net開(kāi)發(fā)中不能分離Model,View和Controller而設(shè)計(jì)的。

普通的網(wǎng)站為了解決可移植富雅,可維護(hù)掸驱,可擴(kuò)展等問(wèn)題,會(huì)把網(wǎng)站設(shè)計(jì)成三個(gè)獨(dú)立的模塊没佑,Model負(fù)責(zé)數(shù)據(jù)庫(kù)部分毕贼,View負(fù)責(zé)網(wǎng)頁(yè)的界面,而Controller負(fù)責(zé)界面與數(shù)據(jù)的交互及業(yè)務(wù)邏輯图筹,這樣設(shè)計(jì)的網(wǎng)站如果想設(shè)計(jì)或者重新開(kāi)發(fā)某一個(gè)模塊對(duì)其他的模塊是沒(méi)有影響的帅刀。但是asp.net的頁(yè)面后臺(tái)代碼與每個(gè)頁(yè)面代碼都是一一對(duì)應(yīng)的,業(yè)務(wù)邏輯在某些情況下不可避免的被寫(xiě)到了與View關(guān)聯(lián)的后臺(tái)代碼中远剩。這樣就不能保證View與Controller的分離扣溺,也就很難實(shí)現(xiàn)網(wǎng)站的重寫(xiě)和升級(jí)。

而在MVC中頁(yè)面代碼并不是與后臺(tái)代碼一一對(duì)應(yīng)瓜晤,而是分別被存放成Controller和View兩個(gè)部分锥余,徹底的解決了,View和Controller不能獨(dú)立的問(wèn)題痢掠。從而改善網(wǎng)站的重寫(xiě)和升級(jí)過(guò)程驱犹。

但是MVC也有其缺點(diǎn),由于在頁(yè)面代碼中不再可以使用服務(wù)器控件足画,因此給某些asp.net服務(wù)器端控件的使用帶來(lái)了麻煩雄驹,而且MVC也頁(yè)面的設(shè)計(jì)工作帶來(lái)了很多障礙。

ASP.NET?MVC?是微軟在2009年4月份發(fā)布的一種新的網(wǎng)站開(kāi)發(fā)架構(gòu)淹辞,http://msdn.microsoft.com/en-us/library/dd394709.aspx医舆,它是把傳統(tǒng)意義上的MVC開(kāi)發(fā)思想融合到了ASP.NET的開(kāi)發(fā)當(dāng)中。

那么我也來(lái)講講我對(duì)這兩者的理解吧象缀。

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

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

首先N層結(jié)構(gòu)是一種軟件抽象的層次結(jié)構(gòu)废封,是對(duì)復(fù)雜軟件的一種縱向切分,每一層次中完成同一類(lèi)型的操作丧蘸,以便將各種代碼以其完成的使命作為依據(jù)來(lái)分割,以將低軟件的復(fù)雜度遥皂,提高其可維護(hù)性力喷。一般來(lái)說(shuō),層次之間是向下依賴(lài)的演训,下層代碼未確定其接口(契約)前弟孟,上層代碼是無(wú)法開(kāi)發(fā)的,下層代碼接口(契約)的變化將使上層的代碼一起變化样悟。三層結(jié)構(gòu)是N層結(jié)構(gòu)的一種拂募,是人產(chǎn)在長(zhǎng)時(shí)間使用中得出來(lái)的一種應(yīng)用場(chǎng)合廣泛的N層結(jié)構(gòu),被當(dāng)作一種典型的軟件層次結(jié)構(gòu)而廣為流傳甚至寫(xiě)入教科書(shū)窟她。

MVC模式是一種復(fù)合設(shè)計(jì)模式陈症,一種在特定場(chǎng)合用于解決某種實(shí)際問(wèn)題來(lái)得出的可以反復(fù)實(shí)踐的解決方案。巧合的是他也有三個(gè)事物組成震糖,于是乎人們就有了一種想當(dāng)然的對(duì)應(yīng)關(guān)系:展示層-View录肯;業(yè)務(wù)邏輯層-Control;持久層-Model吊说。首先MVC中的三個(gè)事物之間并不存在明顯的層次結(jié)構(gòu)论咏,沒(méi)有明顯的向下依賴(lài)關(guān)系,相反的颁井,View和Model往往是比較獨(dú)立的厅贪,而Control是連接兩者的橋梁,他們更像是橫向的切分雅宾。這樣一來(lái)就出現(xiàn)一個(gè)結(jié)果养涮,MVC中每個(gè)塊都是可以獨(dú)立測(cè)試的,而三層結(jié)構(gòu)中秀又,上層模塊的運(yùn)行測(cè)試勢(shì)必要提供下層代碼或者提供相同接口的樁单寂。相對(duì)來(lái)說(shuō),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è)核心框架來(lái)提供棒掠,有擴(kuò)展點(diǎn),但基本上可以簡(jiǎn)單配置不需要任何代碼就可以運(yùn)行屁商。而View則可能是一套或多種可選擇的視圖引擎烟很,決定了軟件展示給用于的界面,使用時(shí)的主要工作量在于擴(kuò)展點(diǎn)以及根據(jù)需要而數(shù)量不同的視圖模板蜡镶。Model則是業(yè)務(wù)提供者雾袱,決定了軟件提供的功能,其內(nèi)部可能是一些普通的類(lèi)或者是實(shí)現(xiàn)了某些接口的類(lèi)官还,在這一塊當(dāng)中可能根據(jù)業(yè)務(wù)的不同而色彩繽紛芹橡,對(duì)于復(fù)雜的軟件可能會(huì)分成很多層,如業(yè)務(wù)邏輯層望伦、業(yè)務(wù)提供層林说、系統(tǒng)提供層、數(shù)據(jù)提供層屯伞、數(shù)據(jù)訪(fǎng)問(wèn)層等腿箩。

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

有朋友提到游戲主機(jī)提供的卡帶插槽的接口,在設(shè)計(jì)中赵刑,有時(shí)也由Control提供一組接口分衫,以用于Model或View的實(shí)現(xiàn),這樣就形成了依賴(lài)般此。一般來(lái)說(shuō)這樣設(shè)計(jì)也沒(méi)有太大的問(wèn)題蚪战,只是會(huì)提高模塊間的耦合度,也會(huì)帶來(lái)一些侵入性铐懊。為了更完美屎勘,可以不用接口來(lái)提供契約,可以用配置信息(或稱(chēng)元數(shù)據(jù)信息)+反射來(lái)提供契約居扒,那么這個(gè)類(lèi)接口就可以退化到只要符合CLS就可以了,也就是普通的類(lèi)丑慎,就像現(xiàn)在的計(jì)算機(jī)接口廣泛采用USB喜喂,無(wú)論是U盤(pán)、打印機(jī)竿裂、掃描儀或者是加密狗玉吁,他們都是普通的USB設(shè)備而已。

提到USB有一個(gè)題外話(huà)腻异,模塊的可插拔性設(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)影斑,需要“安全刪除硬件”類(lèi)似的功能。

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

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市残邀,隨后出現(xiàn)的幾起案子皆辽,更是在濱河造成了極大的恐慌,老刑警劉巖芥挣,帶你破解...
    沈念sama閱讀 210,914評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件驱闷,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡空免,警方通過(guò)查閱死者的電腦和手機(jī)空另,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,935評(píng)論 2 383
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)蹋砚,“玉大人痹换,你說(shuō)我怎么就攤上這事征字。” “怎么了娇豫?”我有些...
    開(kāi)封第一講書(shū)人閱讀 156,531評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵匙姜,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我冯痢,道長(zhǎng)氮昧,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,309評(píng)論 1 282
  • 正文 為了忘掉前任浦楣,我火速辦了婚禮袖肥,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘振劳。我一直安慰自己椎组,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,381評(píng)論 5 384
  • 文/花漫 我一把揭開(kāi)白布历恐。 她就那樣靜靜地躺著寸癌,像睡著了一般。 火紅的嫁衣襯著肌膚如雪弱贼。 梳的紋絲不亂的頭發(fā)上蒸苇,一...
    開(kāi)封第一講書(shū)人閱讀 49,730評(píng)論 1 289
  • 那天,我揣著相機(jī)與錄音吮旅,去河邊找鬼溪烤。 笑死,一個(gè)胖子當(dāng)著我的面吹牛庇勃,可吹牛的內(nèi)容都是我干的檬嘀。 我是一名探鬼主播,決...
    沈念sama閱讀 38,882評(píng)論 3 404
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼责嚷,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼枪眉!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起再层,我...
    開(kāi)封第一講書(shū)人閱讀 37,643評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤贸铜,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后聂受,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體蒿秦,經(jīng)...
    沈念sama閱讀 44,095評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,448評(píng)論 2 325
  • 正文 我和宋清朗相戀三年蛋济,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了棍鳖。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,566評(píng)論 1 339
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖渡处,靈堂內(nèi)的尸體忽然破棺而出镜悉,到底是詐尸還是另有隱情,我是刑警寧澤医瘫,帶...
    沈念sama閱讀 34,253評(píng)論 4 328
  • 正文 年R本政府宣布侣肄,位于F島的核電站,受9級(jí)特大地震影響醇份,放射性物質(zhì)發(fā)生泄漏稼锅。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,829評(píng)論 3 312
  • 文/蒙蒙 一僚纷、第九天 我趴在偏房一處隱蔽的房頂上張望矩距。 院中可真熱鬧,春花似錦怖竭、人聲如沸锥债。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,715評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)哮肚。三九已至,卻和暖如春趣兄,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背悼嫉。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,945評(píng)論 1 264
  • 我被黑心中介騙來(lái)泰國(guó)打工艇潭, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人戏蔑。 一個(gè)月前我還...
    沈念sama閱讀 46,248評(píng)論 2 360
  • 正文 我出身青樓蹋凝,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親总棵。 傳聞我的和親對(duì)象是個(gè)殘疾皇子鳍寂,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,440評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容