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

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

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


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

    以前在看MVC的時候總是被一些教條主義的東西迷惑,說什么在MVC里面,MV解耦,所以M可被替換,V也可被替換。這個時候往往會感到迷惑。為什么模型,或者說數據層要被替換?為什么視圖,或者說界面要被替換?其實這在一個不是復雜到神級級別的程序里面是不會發生的。但是MVC并不是為了讓你能夠實現模型被替換或者試圖被替換而產生出來的,我覺得這個模式(其實這不是設計模式的其中一項,真的)更加重要的特點是可以讓你的程序寫起單元測試來更加容易。

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

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

    答案:MVC。

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

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

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

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

評論:
# re: 為什么要MVC 2010-01-08 04:43 | radar
難怪這些天老沒見師兄更新呢,原來又厲害一把呢  回復  更多評論
  
# re: 為什么要MVC 2010-01-08 07:17 | 千暮(zblc)
我只看到幾個東西: 存在 對比 替換  回復  更多評論
  
# re: 為什么要MVC 2010-01-08 12:27 | 唐僧
單元測試這個地方不是很清楚怎么做,單獨測試m,v,c是很容易的,但是測試它們中間的關聯就不是很容易了(以java為例,listener和event的處理就比較不好測試,也不是不好測,就是這樣測試感覺上不是很舒服)
最近的經驗和教訓都說明了一個問題,解決復雜問題的關鍵在于尋找一種最簡單的方法來描述它,或者說準確建模,對于gui開發來說,不能為了mvc而mvc,解耦合的思想不僅僅有mvc一種方法。  回復  更多評論
  
# re: 為什么要MVC 2010-01-09 21:29 | 空明流轉
你也開始玩虛的了。。。Sigh。應用系統寫多了,你就跟拆遷辦一樣,啥東西都能拆開就拆開。  回復  更多評論
  
# re: 為什么要MVC 2010-01-09 23:09 | 陳梓瀚(vczh)
@空明流轉
娃哈哈,編譯器寫多了難免要搞點虛的放松放松  回復  更多評論
  
# re: 為什么要MVC 2010-01-10 05:35 | vcool
MVC之間的耦合有時候比較難處理?模式處理不好,也很容易亂套!  回復  更多評論
  
# re: 為什么要MVC 2010-01-10 06:25 | 空明流轉
話說MVC還有一個巨大用處,就是不用因為用戶加一個對話框或者數據表改了一個字段名就把代碼改的一塌糊涂。  回復  更多評論
  
# re: 為什么要MVC 2010-01-13 07:43 | wyh
er..這道題目是我每次面試的時候必問的  回復  更多評論
  
# re: 為什么要MVC 2010-02-24 16:58 | junglevass
不錯不錯,學習了。  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            在线欧美亚洲| 性做久久久久久免费观看欧美 | 免费欧美在线视频| 亚洲午夜av在线| 欧美精品aa| 国产日韩欧美精品一区| 免费观看亚洲视频大全| 亚洲欧美在线另类| 在线观看成人小视频| 亚洲高清视频在线| 欧美视频一二三区| 欧美在线视频一区二区三区| 一区二区三区欧美在线观看| 欧美性色综合| 欧美精品在线免费观看| 久久久99免费视频| 欧美激情小视频| 久久久久久黄| 国产精品久久9| 国产精品视频一二| 久久久久久9| 国产精品qvod| 夜夜躁日日躁狠狠久久88av| 尤物九九久久国产精品的特点| 亚洲精品视频免费| 亚洲国产精品小视频| 性欧美videos另类喷潮| 艳妇臀荡乳欲伦亚洲一区| 久久久久久有精品国产| 亚洲午夜久久久久久久久电影院| 国产精品国产a| 久久久一本精品99久久精品66| 亚洲欧美中文在线视频| 亚洲永久精品大片| 久久国产福利| 欧美色区777第一页| 国产日韩欧美麻豆| 国产精品久久久久久五月尺| 国产精品卡一卡二卡三| 一个色综合av| 久久国产欧美精品| 欧美日韩激情网| 亚洲欧洲视频在线| 欧美国产日韩一二三区| 欧美日韩国产成人在线免费| 国产精品久久久久久模特| 中日韩午夜理伦电影免费| 性欧美大战久久久久久久免费观看| 欧美激情精品久久久久| 欧美日本一区二区高清播放视频| 国产偷国产偷亚洲高清97cao| 欧美中文字幕在线播放| 久久久在线视频| 一本色道久久综合狠狠躁的推荐| 精品电影一区| 久久精品日产第一区二区| 国产精品福利在线观看| 亚洲精品在线免费| 欧美尤物一区| 亚洲第一成人在线| 欧美日韩中文字幕在线视频| 欧美一区亚洲二区| 亚洲精品九九| 亚洲综合视频一区| 亚洲国产日韩欧美在线动漫| 国产欧美日韩一区| 欧美日韩国产成人| 久久综合狠狠| 久久精品中文字幕一区| 亚洲欧美综合另类中字| 亚洲精品视频在线| 亚洲电影一级黄| 欧美11—12娇小xxxx| 亚洲欧美日韩一区在线| 亚洲私人影院| 亚洲一区二区动漫| 中日韩午夜理伦电影免费| 亚洲精品无人区| 欧美黄色网络| 亚洲大胆人体视频| 免费在线成人av| 欧美国产精品va在线观看| 久久伊人精品天天| 久久久一二三| 亚洲国产一区二区精品专区| 亚洲国产精品va在线看黑人 | 欧美成人国产va精品日本一级| 一区二区三区|亚洲午夜| 亚洲福利av| 亚洲人在线视频| 夜夜爽夜夜爽精品视频| 国产精品日本欧美一区二区三区| 欧美日本不卡| 国产伦精品一区二区三区照片91| 国产精品久久久久久久久久久久| 国产精品播放| 伊大人香蕉综合8在线视| 亚洲黄色影片| 久久精品视频免费播放| 亚洲国产天堂久久综合| 亚洲影院免费观看| 欧美电影打屁股sp| 国产亚洲欧洲997久久综合| 亚洲三级免费观看| 欧美色区777第一页| 狠狠色狠狠色综合日日小说| 日韩视频免费| 牛牛国产精品| 欧美一区二区三区精品电影| 欧美日韩成人综合在线一区二区| 国产日韩在线亚洲字幕中文| 中文成人激情娱乐网| 欧美国产日韩在线| 久久不射电影网| 国产曰批免费观看久久久| 亚洲私人影吧| 中文av一区特黄| 国产精品视频你懂的| 在线亚洲自拍| 夜夜嗨av一区二区三区| 欧美激情无毛| 亚洲视频在线观看网站| 99精品视频免费观看| 欧美理论在线播放| 亚洲欧美日韩精品久久久| 91久久精品国产91久久| 久久亚洲精品视频| 国外成人网址| 欧美激情一二区| 欧美日韩国产限制| 亚洲欧美日韩成人| 亚洲视频在线观看一区| 国产日韩免费| 欧美国产视频在线观看| 免费国产自线拍一欧美视频| 亚洲尤物在线| 狠狠色综合色区| 亚洲高清自拍| 欧美午夜不卡| 免费观看欧美在线视频的网站| 亚洲国产高潮在线观看| 日韩一区二区精品葵司在线| 欧美色欧美亚洲另类七区| 亚洲一区二区三区四区中文 | 久久精品亚洲| 欧美色偷偷大香| 免费高清在线一区| 欧美日韩一区综合| 免费在线成人| 国产欧美一区二区精品性色| 欧美国产精品久久| 国产一区二区三区在线观看视频 | 欧美精品色网| 欧美成人精品在线播放| 国产原创一区二区| 久久视频免费观看| 国产精品福利在线观看| 性欧美大战久久久久久久久| 欧美大片一区二区| 韩国视频理论视频久久| 激情小说亚洲一区| 亚洲一区999| 午夜精品视频网站| 欧美午夜视频网站| 亚洲小视频在线观看| 一区二区激情视频| 欧美日韩精品免费观看| 亚洲激情在线激情| 亚洲最新中文字幕| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ入口 | 国产午夜精品美女毛片视频| 一区二区欧美日韩| 一区二区久久久久| 欧美区日韩区| 一区二区动漫| 久久精品视频一| 亚洲电影专区| 欧美日韩国产一区精品一区| 日韩一级大片在线| 久久精品一区二区三区不卡| 国产一区二区三区电影在线观看| 欧美一区激情视频在线观看| 久久综合九色欧美综合狠狠| 亚洲成人在线| 国产精品美女主播在线观看纯欲| 亚洲一区二区在线免费观看| 久久在线免费观看视频| 最新国产乱人伦偷精品免费网站| 欧美国产欧美亚洲国产日韩mv天天看完整 | 久久www免费人成看片高清 | 99天天综合性| 国产在线视频欧美一区二区三区| 久热精品视频在线观看一区| 99在线精品观看| 欧美成人精品三级在线观看| 中文日韩在线| 99精品国产在热久久婷婷| 国产日韩欧美不卡| 欧美日韩中文精品| 欧美日韩免费一区二区三区视频|