青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆-341  評論-2670  文章-0  trackbacks-0

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


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

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

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

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

    答案:MVC。

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

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

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

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

評論:
# re: 為什么要MVC 2010-01-08 04:43 | radar
難怪這些天老沒見師兄更新呢,原來又厲害一把呢  回復(fù)  更多評論
  
# re: 為什么要MVC 2010-01-08 07:17 | 千暮(zblc)
我只看到幾個東西: 存在 對比 替換  回復(fù)  更多評論
  
# re: 為什么要MVC 2010-01-08 12:27 | 唐僧
單元測試這個地方不是很清楚怎么做,單獨測試m,v,c是很容易的,但是測試它們中間的關(guān)聯(lián)就不是很容易了(以java為例,listener和event的處理就比較不好測試,也不是不好測,就是這樣測試感覺上不是很舒服)
最近的經(jīng)驗和教訓(xùn)都說明了一個問題,解決復(fù)雜問題的關(guān)鍵在于尋找一種最簡單的方法來描述它,或者說準(zhǔn)確建模,對于gui開發(fā)來說,不能為了mvc而mvc,解耦合的思想不僅僅有mvc一種方法。  回復(fù)  更多評論
  
# re: 為什么要MVC 2010-01-09 21:29 | 空明流轉(zhuǎn)
你也開始玩虛的了。。。Sigh。應(yīng)用系統(tǒng)寫多了,你就跟拆遷辦一樣,啥東西都能拆開就拆開。  回復(fù)  更多評論
  
# re: 為什么要MVC 2010-01-09 23:09 | 陳梓瀚(vczh)
@空明流轉(zhuǎn)
娃哈哈,編譯器寫多了難免要搞點虛的放松放松  回復(fù)  更多評論
  
# re: 為什么要MVC 2010-01-10 05:35 | vcool
MVC之間的耦合有時候比較難處理?模式處理不好,也很容易亂套!  回復(fù)  更多評論
  
# re: 為什么要MVC 2010-01-10 06:25 | 空明流轉(zhuǎn)
話說MVC還有一個巨大用處,就是不用因為用戶加一個對話框或者數(shù)據(jù)表改了一個字段名就把代碼改的一塌糊涂。  回復(fù)  更多評論
  
# re: 為什么要MVC 2010-01-13 07:43 | wyh
er..這道題目是我每次面試的時候必問的  回復(fù)  更多評論
  
# re: 為什么要MVC 2010-02-24 16:58 | junglevass
不錯不錯,學(xué)習(xí)了。  回復(fù)  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            午夜视频一区在线观看| 欧美一级免费视频| 欧美理论片在线观看| 亚洲啪啪91| 亚洲美女视频网| 国产精品久久久久影院色老大| 亚洲在线视频免费观看| 亚洲免费视频在线观看| 国产亚洲a∨片在线观看| 久久综合给合久久狠狠色| 久久人91精品久久久久久不卡| 亚洲国产成人精品久久久国产成人一区| 欧美va亚洲va日韩∨a综合色| 免费观看成人鲁鲁鲁鲁鲁视频| 亚洲久久一区| 亚洲网站视频| 激情文学一区| 99精品欧美一区二区三区 | 欧美专区福利在线| 1769国产精品| 宅男66日本亚洲欧美视频 | 欧美激情精品久久久久久久变态 | 亚洲亚洲精品在线观看| 亚洲男女毛片无遮挡| 亚洲二区在线观看| 亚洲图片欧美午夜| 亚洲高清视频在线观看| 亚洲视频精品| 亚洲国产综合91精品麻豆| 国产精品99久久久久久www| 激情欧美亚洲| 亚洲一区二区3| 亚洲精品午夜精品| 欧美一区二区视频在线观看2020 | 亚洲在线播放电影| 久久综合婷婷| 久久久精品999| 欧美日韩一区二区国产| 麻豆国产精品一区二区三区 | 欧美激情视频在线播放| 久久国产日本精品| 欧美日韩在线一区| 久久综合给合久久狠狠色| 国产精品久久国产三级国电话系列| 久久先锋资源| 国产日韩欧美在线看| 一区二区三区**美女毛片| 亚洲人成啪啪网站| 久久中文字幕导航| 久久午夜激情| 国产日韩欧美在线观看| 一区二区不卡在线视频 午夜欧美不卡在 | 久久婷婷久久| 久久美女性网| 国产亚洲精品一区二555| 99re66热这里只有精品4| 亚洲清纯自拍| 欧美成人午夜77777| 欧美不卡在线视频| 伊人婷婷欧美激情| 欧美亚洲一区二区在线观看| 午夜欧美大片免费观看| 国产精品美女在线| 宅男噜噜噜66一区二区 | 国产精品美腿一区在线看| 日韩视频在线观看国产| 日韩一区二区精品| 欧美激情综合五月色丁香小说| 亚洲第一中文字幕| 亚洲国产成人一区| 欧美成人精品一区二区三区| 欧美成人一二三| 亚洲精品在线视频观看| 欧美精品高清视频| 在线一区二区三区四区五区| 亚洲欧美日韩一区二区| 国产日韩在线一区| 久久激情视频久久| 欧美国产先锋| 亚洲天堂成人| 国产免费亚洲高清| 久久久久一区二区三区| 欧美国产先锋| 亚洲小说春色综合另类电影| 国产精品日韩一区二区| 午夜精品一区二区三区在线| 另类激情亚洲| 亚洲免费观看在线观看| 欧美色大人视频| 欧美一区二区三区日韩| 欧美国产日韩一区| 亚洲午夜激情网站| 黄色资源网久久资源365| 欧美国产一区二区三区激情无套| 亚洲三级免费电影| 欧美一区二区三区视频免费播放 | 韩曰欧美视频免费观看| 欧美1区免费| 亚洲少妇最新在线视频| 美女视频网站黄色亚洲| 一区二区三区四区五区精品视频| 国产精品久久久久一区二区| 久久久久久久久久久久久女国产乱 | 欧美中日韩免费视频| 亚洲国产你懂的| 欧美一区免费视频| 亚洲毛片一区| 国产一区二区你懂的| 欧美精品性视频| 欧美资源在线| 99天天综合性| 欧美国产精品v| 久久成人精品一区二区三区| 亚洲精品在线观| 国内精品久久久久久久97牛牛| 欧美华人在线视频| 久久精视频免费在线久久完整在线看| 91久久精品国产| 免费观看一区| 久久精品麻豆| 亚洲欧美电影在线观看| 亚洲人成免费| 伊人春色精品| 国产一区在线观看视频| 国产精品video| 欧美另类极品videosbest最新版本| 欧美亚洲视频在线观看| 一区二区三区精品视频在线观看| 欧美国产一区在线| 免费成人黄色| 久久久久久电影| 亚洲一区二区三区乱码aⅴ蜜桃女| 亚洲国产一区二区三区青草影视| 国际精品欧美精品| 国产毛片精品国产一区二区三区| 欧美色图五月天| 欧美日韩国产va另类| 欧美精品成人91久久久久久久| 久热精品视频在线| 久久久av水蜜桃| 久久精品女人的天堂av| 午夜精品成人在线视频| 亚洲视频免费看| 亚洲永久免费视频| 午夜精品视频| 久久精品人人做人人爽电影蜜月| 亚洲欧美日韩视频二区| 午夜精品一区二区三区电影天堂| 亚洲欧美日韩国产成人精品影院| 亚洲天堂成人在线视频| 亚洲欧美美女| 久久精品一区二区三区四区| 欧美一级黄色网| 久久精品国产精品| 久久麻豆一区二区| 蜜桃伊人久久| 欧美日韩精品综合| 国产精品久久久久国产精品日日| 国产精品免费aⅴ片在线观看| 国产欧美69| 伊人成人开心激情综合网| 亚洲黄色影片| 亚洲一区日本| 久久天天躁狠狠躁夜夜av| 免费不卡在线观看av| 亚洲韩国日本中文字幕| 一二三区精品| 久久精品亚洲乱码伦伦中文 | 欧美国产日本| 国产精品久久久久久久久久尿| 国产精品一区视频| 亚洲第一中文字幕在线观看| 亚洲精品九九| 欧美在线观看一区二区| 欧美3dxxxxhd| 中文国产成人精品久久一| 欧美专区日韩视频| 欧美精品久久久久久久久老牛影院| 国产精品jvid在线观看蜜臀| 精品av久久久久电影| 99精品欧美一区二区蜜桃免费| 午夜精品一区二区在线观看 | 亚洲一区精品在线| 久久亚洲精品一区| 日韩午夜电影在线观看| 久久精品国产久精国产一老狼| 欧美高清在线视频观看不卡| 国产麻豆精品在线观看| 日韩午夜视频在线观看| 久久久999精品| 99国产精品国产精品毛片| 久久久精品国产99久久精品芒果| 欧美精品在线网站| 一区二区三区在线观看欧美| 亚洲欧美国产三级| 亚洲人成毛片在线播放| 久久久精品视频成人| 国产精品视频网站| 一区二区三区国产在线| 欧美激情a∨在线视频播放|