• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆-341  評(píng)論-2670  文章-0  trackbacks-0

                最近在公司寫(xiě)了一大堆復(fù)雜的界面,終于體會(huì)到了前輩們那種上刀山下火海的感覺(jué)了。做完了之后回頭想想,MVC還是有道理的。


                什么是MVC?其實(shí)可以簡(jiǎn)單的理解為一個(gè)有UI的程序可以劃分為三個(gè)部分:數(shù)據(jù)層、邏輯層和應(yīng)用層。當(dāng)然這些名字是我亂起的。數(shù)據(jù)層顧名思義就是用來(lái)讀寫(xiě)數(shù)據(jù)的地方,譬如說(shuō)一個(gè)電話本的文件。邏輯層就是用戶(hù)在界面上的操作的抽象,譬如說(shuō)要通過(guò)名字來(lái)查找消息啦,給一個(gè)關(guān)鍵字求得篩選后的電話信息列表啦。應(yīng)用層指的就是那一堆控件了。MVC三個(gè)字母分別指的是Model、View和Controller,也就是模型、視圖和控制器了,分別對(duì)應(yīng)于數(shù)據(jù)層、應(yīng)用層和邏輯層。

                以前在看MVC的時(shí)候總是被一些教條主義的東西迷惑,說(shuō)什么在MVC里面,MV解耦,所以M可被替換,V也可被替換。這個(gè)時(shí)候往往會(huì)感到迷惑。為什么模型,或者說(shuō)數(shù)據(jù)層要被替換?為什么視圖,或者說(shuō)界面要被替換?其實(shí)這在一個(gè)不是復(fù)雜到神級(jí)級(jí)別的程序里面是不會(huì)發(fā)生的。但是MVC并不是為了讓你能夠?qū)崿F(xiàn)模型被替換或者試圖被替換而產(chǎn)生出來(lái)的,我覺(jué)得這個(gè)模式(其實(shí)這不是設(shè)計(jì)模式的其中一項(xiàng),真的)更加重要的特點(diǎn)是可以讓你的程序?qū)懫饐卧獪y(cè)試來(lái)更加容易。

                還是電話本,現(xiàn)在有一個(gè)要求,說(shuō)在輸入人的名字之后,只要系統(tǒng)檢查出你超過(guò)0.5秒沒(méi)有持續(xù)輸入,那么底下的列表就會(huì)自動(dòng)根據(jù)你上面的輸入進(jìn)行篩選。其實(shí)這有點(diǎn)像Outlook。這要怎么寫(xiě)單元測(cè)試?我們知道雖然正規(guī)的測(cè)試會(huì)有一大堆用來(lái)自動(dòng)完成界面操作的工具啊,或者類(lèi)庫(kù),但是作為單元測(cè)試來(lái)講我們并不需要去做這種事情。因?yàn)閱卧獪y(cè)試是程序員寫(xiě)的,凡是程序員寫(xiě)的東西當(dāng)然是需要盡快得到結(jié)果的。一般的開(kāi)發(fā)方法是寫(xiě)一點(diǎn)代碼,寫(xiě)一點(diǎn)測(cè)試,跑,有bug改沒(méi)有bug繼續(xù)。我們?cè)陂_(kāi)發(fā)程序的時(shí)候會(huì)不斷地、頻繁地跑單元測(cè)試,來(lái)看看我們的東西是不是有問(wèn)題,或者在重構(gòu)的時(shí)候我們對(duì)于我們的代碼正確的信心會(huì)大一點(diǎn)。

                那界面怎么辦呢?難道我們真的要去引入一個(gè)庫(kù)來(lái)搞界面的自動(dòng)測(cè)試嗎?當(dāng)然想要也可以,不過(guò)這畢竟太復(fù)雜,而且這一類(lèi)的工具的穩(wěn)定性其實(shí)都不是特別好,被誤導(dǎo)的幾率倒是大增。這僅僅是對(duì)于程序員來(lái)講的,當(dāng)然搞測(cè)試的那些人自有他們的辦法。那既然我們不做界面的自動(dòng)測(cè)試那怎么知道文本框被輸入之后究竟篩選出來(lái)的數(shù)據(jù)對(duì)還是不對(duì)呢?

                答案:MVC。

                為什么View,也就是試圖,也就是界面,可以被替換是一件很重要的事情?想一想,如果控件可以被換成單元測(cè)試的一段代碼,那豈不是很爽么?舉個(gè)例子,我們要告知用戶(hù)說(shuō),我們的事情已經(jīng)做了一半了,這個(gè)時(shí)候我們可能會(huì)去設(shè)置進(jìn)度條的位置。但是“告訴用戶(hù)說(shuō)我們的事情已經(jīng)做了一半”跟“設(shè)置進(jìn)度條的位置”其實(shí)是完全無(wú)關(guān)的兩件事情。因此我們的Controller要負(fù)責(zé)通知View說(shuō)事情做了一半了,然后View就可以去設(shè)置進(jìn)度條的位置了。現(xiàn)在我們把View換成單元測(cè)試的一段代碼,這個(gè)時(shí)候就變成Controller通知測(cè)試程序說(shuō)事情已經(jīng)做到一半了,然后測(cè)試程序就會(huì)去檢查說(shuō)現(xiàn)在是不是應(yīng)該做到了一半,如果應(yīng)該,顯然這個(gè)用例就通過(guò)了。

                那Model呢?Model可以簡(jiǎn)單的理解為數(shù)據(jù)源,其實(shí)當(dāng)然不只是那么簡(jiǎn)單,不過(guò)這樣理解會(huì)讓我們更容易接受一點(diǎn)。數(shù)據(jù)源是什么,當(dāng)你寫(xiě)單元測(cè)試的時(shí)候,去連接一個(gè)數(shù)據(jù)庫(kù)來(lái)獲得數(shù)據(jù)源,然后就操作Controller,這個(gè)時(shí)候你如果不親自去讀一下數(shù)據(jù)庫(kù),你怎么知道Controller給你的東西究竟是對(duì)的還是錯(cuò)的?顯然Model我們也可以換掉,測(cè)試程序偽造數(shù)據(jù)成為一個(gè)Model,然后插入Controller,事情就解決了。數(shù)據(jù)是我們自己給的,那Controller應(yīng)該提供什么我們也能知道了。

                于是,使用了MVC之后,單元測(cè)試想換Model就換Model,想換View就換View,測(cè)試什么就非常容易了。至于說(shuō)用戶(hù)停止輸入0.5秒之后是不是會(huì)真的去進(jìn)行數(shù)據(jù)的篩選,這個(gè)我們手工測(cè)試就好了,而且那些搞測(cè)試的人也會(huì)幫我們檢查的。

                好吧,說(shuō)到這里有人可能會(huì)問(wèn)為什么我沒(méi)有給出一個(gè)Demo?這東西太虛,實(shí)踐實(shí)踐自己體會(huì)一下就行了,而且MVC變形那么多,有Model-View-Presenter,還有最近興起的Model-View-ViewModel等等,其實(shí)現(xiàn)都跟傳說(shuō)中的那個(gè)類(lèi)似橋接模式的東西差別甚遠(yuǎn)。這個(gè)自己去看一看就好了。
            posted on 2010-01-08 03:58 陳梓瀚(vczh) 閱讀(5075) 評(píng)論(9)  編輯 收藏 引用 所屬分類(lèi): 啟示

            評(píng)論:
            # re: 為什么要MVC 2010-01-08 04:43 | radar
            難怪這些天老沒(méi)見(jiàn)師兄更新呢,原來(lái)又厲害一把呢  回復(fù)  更多評(píng)論
              
            # re: 為什么要MVC 2010-01-08 07:17 | 千暮(zblc)
            我只看到幾個(gè)東西: 存在 對(duì)比 替換  回復(fù)  更多評(píng)論
              
            # re: 為什么要MVC 2010-01-08 12:27 | 唐僧
            單元測(cè)試這個(gè)地方不是很清楚怎么做,單獨(dú)測(cè)試m,v,c是很容易的,但是測(cè)試它們中間的關(guān)聯(lián)就不是很容易了(以java為例,listener和event的處理就比較不好測(cè)試,也不是不好測(cè),就是這樣測(cè)試感覺(jué)上不是很舒服)
            最近的經(jīng)驗(yàn)和教訓(xùn)都說(shuō)明了一個(gè)問(wèn)題,解決復(fù)雜問(wèn)題的關(guān)鍵在于尋找一種最簡(jiǎn)單的方法來(lái)描述它,或者說(shuō)準(zhǔn)確建模,對(duì)于gui開(kāi)發(fā)來(lái)說(shuō),不能為了mvc而mvc,解耦合的思想不僅僅有mvc一種方法。  回復(fù)  更多評(píng)論
              
            # re: 為什么要MVC 2010-01-09 21:29 | 空明流轉(zhuǎn)
            你也開(kāi)始玩虛的了。。。Sigh。應(yīng)用系統(tǒng)寫(xiě)多了,你就跟拆遷辦一樣,啥東西都能拆開(kāi)就拆開(kāi)。  回復(fù)  更多評(píng)論
              
            # re: 為什么要MVC 2010-01-09 23:09 | 陳梓瀚(vczh)
            @空明流轉(zhuǎn)
            娃哈哈,編譯器寫(xiě)多了難免要搞點(diǎn)虛的放松放松  回復(fù)  更多評(píng)論
              
            # re: 為什么要MVC 2010-01-10 05:35 | vcool
            MVC之間的耦合有時(shí)候比較難處理?模式處理不好,也很容易亂套!  回復(fù)  更多評(píng)論
              
            # re: 為什么要MVC 2010-01-10 06:25 | 空明流轉(zhuǎn)
            話說(shuō)MVC還有一個(gè)巨大用處,就是不用因?yàn)橛脩?hù)加一個(gè)對(duì)話框或者數(shù)據(jù)表改了一個(gè)字段名就把代碼改的一塌糊涂。  回復(fù)  更多評(píng)論
              
            # re: 為什么要MVC 2010-01-13 07:43 | wyh
            er..這道題目是我每次面試的時(shí)候必問(wèn)的  回復(fù)  更多評(píng)論
              
            # re: 為什么要MVC 2010-02-24 16:58 | junglevass
            不錯(cuò)不錯(cuò),學(xué)習(xí)了。  回復(fù)  更多評(píng)論
              
            99久久久精品免费观看国产| 亚州日韩精品专区久久久| 欧美噜噜久久久XXX| 天天久久狠狠色综合| 久久久精品波多野结衣| 亚洲国产精品无码成人片久久| 久久一日本道色综合久久| 久久精品成人免费观看97| 欧美熟妇另类久久久久久不卡 | 欧美与黑人午夜性猛交久久久| 久久婷婷午色综合夜啪| 亚洲国产精品久久66| 亚洲va久久久噜噜噜久久狠狠| 国产精品亚洲美女久久久| 色婷婷综合久久久久中文一区二区| 国产精品gz久久久| 99久久精品国产高清一区二区 | 亚洲欧美日韩精品久久| 欧美激情一区二区久久久| 999久久久免费国产精品播放| 亚洲综合精品香蕉久久网| 久久99亚洲综合精品首页| 久久99国产综合精品女同| 亚洲色大成网站WWW久久九九| 久久久受www免费人成| 亚洲天堂久久精品| 久久久久久综合一区中文字幕 | 思思久久好好热精品国产| 国产免费久久精品99久久| 成人国内精品久久久久影院VR| 精品无码久久久久久午夜| 久久狠狠高潮亚洲精品| 99久久99久久精品免费看蜜桃| 狠狠88综合久久久久综合网 | 久久无码专区国产精品发布| 蜜桃麻豆www久久国产精品| 久久一区二区免费播放| 香蕉久久永久视频| 伊人久久大香线蕉综合Av| 久久久精品国产sm调教网站| 国产精品久久久久无码av|