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

woaidongmao

文章均收錄自他人博客,但不喜標(biāo)題前加-[轉(zhuǎn)貼],因其丑陋,見諒!~
隨筆 - 1469, 文章 - 0, 評論 - 661, 引用 - 0
數(shù)據(jù)加載中……

MVC模式和文檔/視圖結(jié)構(gòu)

       MVC(Model-View-Controller)模式的基本思想是數(shù)據(jù),顯示和處理相分離。模型(Model)負責(zé)數(shù)據(jù)管理,視圖(View)負責(zé)數(shù)據(jù)顯示,控制器(Controller)負責(zé)業(yè)務(wù)邏輯和響應(yīng)策略。
       從MVC的形成過程來看,最初只有模型和視圖兩個元素。模型封裝了數(shù)據(jù)并提供操作接口,視圖用來表現(xiàn)數(shù)據(jù)和接收用戶請求。模型是獨立的,而視圖依賴于模型:從模型獲取數(shù)據(jù)進行顯示;向模型發(fā)送用戶請求,并根據(jù)返回結(jié)果刷新自己。
       需要用多個視圖表現(xiàn)同一模型時,情況發(fā)生了變化:一個視圖修改數(shù)據(jù)以后,不但本身要刷新,其他所有視圖也要刷新。如果由該視圖通知其他視圖,它就需要知道其他所有視圖,由于每個視圖都可能發(fā)出修改,每個視圖都要知道其他所有視圖,這種關(guān)聯(lián)過于復(fù)雜,不但難以維護,而且不便于增加新的視圖。如果讓模型通知所有視圖更新,可能會影響模型的獨立性。用觀察者(Observer)模式可以解決上述矛盾,從而實現(xiàn):由模型通知視圖,而模型不依賴于具體的視圖,具體視圖之間相互獨立。
       視圖是用戶請求的接收者,但不宜作為請求的處理者。因為界面是易變的,如果業(yè)務(wù)代碼和界面代碼放在一起,頻繁的界面修改可能會破壞比較穩(wěn)定的業(yè)務(wù)代碼。將業(yè)務(wù)邏輯分離出來,由一個控制器負責(zé),就是為了避免這種干擾。
       模型,視圖和控制器的基本協(xié)作關(guān)系如下圖
clip_image001
       模型在狀態(tài)變化的時候,直接通知所有視圖,視圖向模型查詢狀態(tài)數(shù)據(jù),然后刷新自身。當(dāng)用戶發(fā)出操作時,視圖把消息發(fā)給控制器,控制器按照業(yè)務(wù)邏輯進行處理,需要查詢或更新數(shù)據(jù)時,控制器會調(diào)用模型。下面是一個更詳細的示意圖
clip_image002
clip_image003
       同樣的數(shù)據(jù),可以有不同的顯示和進行各種處理。顯示僅僅是表現(xiàn)數(shù)據(jù),而處理是根據(jù)用戶請求改變數(shù)據(jù)的過程,不但包含業(yè)務(wù)邏輯,也要提供響應(yīng)策略。響應(yīng)策略由控制器負責(zé),視圖可以使用不同的控制器提供不同的響應(yīng)方式,這是策略(Strategy)模式的應(yīng)用。
       此外,MVC還允許視圖嵌套,通過使用組合(Composite)模式,一致地處理組合視圖和普通視圖。
       用多個視圖表現(xiàn)一個模型,在視圖不變的情況下改變響應(yīng)策略,允許視圖嵌套,這是MVC的三個主要特性。在內(nèi)部結(jié)構(gòu)上,MVC的主要關(guān)系是由觀察者模式,策略模式和組合模式給出的。由觀察者模式確定的模型視圖關(guān)系是其中最為重要的。
       MVC模式有許多變體。前述結(jié)構(gòu)中,由模型通知視圖刷新,稱為主動MVC;如果由控制器更新模型以后通知視圖,稱為被動MVC結(jié)構(gòu)。在許多應(yīng)用中,沒有明顯的控制器角色,也沒有視圖嵌套。可見根據(jù)實際需要,構(gòu)成MVC的三個模式上都可能出現(xiàn)變化。Web瀏覽器就是被動MVC結(jié)構(gòu)的一個實例。

clip_image004
       “瀏覽器是一個交互程序,從概念上講,它是由一組客戶、一組解釋器與一個管理它們的控制器所組成。控制器形成了瀏覽器的中心部件,它解釋鼠標(biāo)點擊與鍵盤輸入,并且調(diào)用其他組件來執(zhí)行用戶指定的操作。例如,當(dāng)用戶鍵入一個URL或者點擊一個超文本引用時,控制器調(diào)用一個客戶從所需文檔所在的遠程服務(wù)器上取回該文檔,并且調(diào)用解釋器向用戶顯示該文檔。每個瀏覽器必須包含一個HTML解釋器來顯示文檔,其他解釋器是可選的。HTML解釋器的輸入由符合HTML語法的文檔所組成,輸出由位于用戶顯示器上的格式版本文檔所組成。解釋器通過將HTML規(guī)則轉(zhuǎn)換成適合用戶顯示硬件的命令來處理版面細節(jié)。HTML解釋器一個最重要的功能是包含可選項。解釋器必須存儲關(guān)于顯示器上位置之間關(guān)系的信息和HTML文檔中被瞄定的項。當(dāng)用戶用鼠標(biāo)選定了一個項,瀏覽器通過當(dāng)前的光標(biāo)位置和存儲的位置信息來決定哪個項被用戶選定。”(參考資料5)

       MFC的文檔/視圖結(jié)構(gòu)(Document/View architecture)是MVC模式的一種變體,下面討論它是怎樣實現(xiàn)的。
       文檔/視圖結(jié)構(gòu)沒有體現(xiàn)業(yè)務(wù)邏輯和視圖的分離,但是將響應(yīng)策略和視圖區(qū)分開來。它主要包含四種對象:

1. 文檔

2. 視圖

3. 視圖框架窗口

4. 文檔模板

       這里的視圖框架窗口定義了視圖對用戶輸入的響應(yīng)方式,而文檔模板用來管理前三種對象的組合。文檔,視圖,視圖框架窗口三者是對應(yīng)的,從而構(gòu)成一個三元組。一個應(yīng)用程序可能需要多個這樣的三元組,以實現(xiàn)文檔的多視圖,所以引入文檔模板來表示該三元組。因為程序中可能使用多個文檔模板,MFC用一個文檔管理者對象來管理它們。
       在MFC中,應(yīng)用程序和主框架窗口是用來封裝底層機制的對象,文檔,視圖,視圖框架窗口和文檔模板是用來構(gòu)架文檔/視圖結(jié)構(gòu)的對象。應(yīng)用程序通過文檔管理者來使用文檔/視圖結(jié)構(gòu)。
       如果要給文檔增加一種視圖,只需要增加一個文檔模板;如果要改變一種視圖的響應(yīng)策略,只要改變對應(yīng)文檔模板中的視圖框架窗口。

 

==================================================================================================================

       軟件設(shè)計中會碰到這樣的關(guān)系:一個對象依賴于另一個對象,必須根據(jù)后者的狀態(tài)更新自己的狀態(tài),可以把后者稱作目標(biāo)對象,前者稱作觀察者對象。不但觀察者依賴于目標(biāo),當(dāng)目標(biāo)的狀態(tài)改變時也要通知觀察者,這就出現(xiàn)了雙向的依賴。兩個對象互相依賴的后果是它們必須一起復(fù)用。如果一個目標(biāo)有多個觀察者,那么目標(biāo)也依賴所有觀察者,從而目標(biāo)對象無法獨立復(fù)用。如何消除目標(biāo)和觀察者之間的互相依賴呢?觀察者模式幫助我們解決這個問題。
觀察者模式把目標(biāo)對觀察者的依賴進行抽象:使目標(biāo)只知道自己有若干觀察者,但不知道這些觀察者具體是誰,可能有多少個;當(dāng)目標(biāo)狀態(tài)改變時只要給這些觀察者一個通知,不必作更多的事情。這樣目標(biāo)對觀察者的依賴就達到了抽象和最小,而目標(biāo)對具體觀察者的依賴被解除了。
       類圖如下:
clip_image001[5]clip_image002
       Subject對象保存一個Observer引用的列表,當(dāng)我們讓一個ConcreteObserver對象觀察Subject對象時,調(diào)用后者的Attach()方法,將前者的引用加入該列表中。當(dāng)Subject對象狀態(tài)改變時,它調(diào)用自身的Notify方法,該方法調(diào)用列表中每一個Observer的Update()方法。一個ConcreteObserver只要重定義Update()就能收到通知,作為對通知的響應(yīng),Update()調(diào)用Subject對象的getStatus()獲取數(shù)據(jù),然后更新自身。當(dāng)不需要繼續(xù)觀察時,ConcreteObserver對象調(diào)用Subject對象的Detach()方法,其引用被從列表中移除。


       解除目標(biāo)對具體觀察者的依賴以后,很容易增加新的具體觀察者,因為不受依賴的方面就可以自由變化;而目標(biāo)也可以獨立地復(fù)用,因為無所依賴的方面就可以不受影響。
       以上主要考慮了一個目標(biāo)有多個觀察者的情況,我們設(shè)法解除了目標(biāo)對具體觀察者的依賴,使具體觀察者的種類和數(shù)目容易改變。有時候一個觀察者觀察多個目標(biāo)也是有意義的,在前面的類圖中,觀察者對具體目標(biāo)的依賴仍然存在,因此無法適應(yīng)目標(biāo)方面的變化。怎樣抽象這種依賴呢?使觀察者只知道若干個目標(biāo)會向自己發(fā)出通知,而不知道這些目標(biāo)具體是誰,可能有多少個;在目標(biāo)向觀察者發(fā)送通知時,將一個自身的引用作為參數(shù),然后觀察者調(diào)用其抽象方法就可以獲得目標(biāo)狀態(tài)。這就使得觀察者對目標(biāo)的依賴是抽象的,觀察者對具體目標(biāo)的依賴被解除了。
       類圖如下:
clip_image003

 


參考資料:
1.《設(shè)計模式-可復(fù)用面向?qū)ο筌浖幕A(chǔ)》/Erich Gamma等著,李英軍等譯 機械工業(yè)出版社
2.《Java與模式》/閻宏 電子工業(yè)出版社
3.  模型-視圖-控制器 ( MSDN > 技術(shù)資源庫 > 體系結(jié)構(gòu) > 使用 Microsoft .NET 的企業(yè)解決方案模式 >第3章 Web 表示模式)
4. 《Java設(shè)計:對象,UML和過程》/Kirk Knoernschild 著,羅英偉等譯 人民郵電出版社
5. 《計算機網(wǎng)絡(luò)與因特網(wǎng)》/D.E.Comer 著 徐良賢等譯 機械工業(yè)出版社
6.《深入解析MFC》/中國電力出版社
7.《VC技術(shù)內(nèi)幕》第5版 / 希望電子出版社

posted on 2008-08-04 23:13 肥仔 閱讀(2974) 評論(2)  編輯 收藏 引用 所屬分類: 設(shè)計模式

評論

# re: MVC模式和文檔/視圖結(jié)構(gòu)  回復(fù)  更多評論   

好東西,支持樓主
2010-11-16 19:38 | sdqxcxh

# re: MVC模式和文檔/視圖結(jié)構(gòu)[未登錄]  回復(fù)  更多評論   

支持樓主!
2013-08-16 15:01 | 123
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久精品亚洲热| 欧美午夜电影完整版| 久久躁狠狠躁夜夜爽| 午夜宅男欧美| 亚洲综合欧美日韩| 亚洲欧美第一页| 亚洲欧美一区二区原创| 亚洲午夜精品17c| 亚洲欧美日韩区| 欧美呦呦网站| 美女脱光内衣内裤视频久久网站| 久久一区二区三区国产精品| 久久久天天操| 国产日韩欧美自拍| 在线成人免费视频| 日韩亚洲欧美一区二区三区| 在线一区二区三区做爰视频网站| 亚洲一区二区不卡免费| 欧美影院久久久| 亚洲大胆av| 免费一级欧美片在线观看| 欧美激情四色| 在线亚洲激情| 久久这里只精品最新地址| 欧美v国产在线一区二区三区| 欧美精品日本| 国产视频一区在线观看| 亚洲国产日本| 亚洲免费在线观看视频| 久久一区二区三区av| 99视频一区二区| 久久精精品视频| 亚洲免费观看高清在线观看 | 牛牛影视久久网| 欧美日韩亚洲一区| 精品av久久707| 在线综合亚洲欧美在线视频| 久久久欧美精品sm网站| 亚洲精品视频一区二区三区| 欧美尤物巨大精品爽| 欧美性一区二区| 亚洲免费电影在线| 麻豆国产精品va在线观看不卡| 999在线观看精品免费不卡网站| 欧美一区视频| 国产精品实拍| 亚洲综合视频网| 日韩亚洲在线观看| 久久综合久色欧美综合狠狠 | 韩曰欧美视频免费观看| 亚洲一区二区三区免费在线观看| 欧美成人dvd在线视频| 亚洲自拍电影| 国产精品久久久久久久久久免费| 亚洲精选久久| 亚洲电影av| 欧美aa在线视频| 亚洲第一主播视频| 久久蜜桃精品| 久久精品视频在线| 国产亚洲欧美aaaa| 欧美在线观看www| 亚洲欧美激情四射在线日| 国产精品麻豆成人av电影艾秋| 一区二区三区毛片| 午夜视黄欧洲亚洲| 日韩小视频在线观看专区| 欧美精品性视频| 一区二区三区 在线观看视频 | 91久久久久久| 欧美sm极限捆绑bd| 亚洲人午夜精品| 亚洲国产一区在线| 欧美成人综合在线| 99热免费精品| 一区二区三区国产精品| 国产精品美女久久久免费| 亚洲自拍三区| 欧美一区中文字幕| 狠狠色2019综合网| 欧美激情精品久久久久久黑人| 免费一级欧美片在线播放| 亚洲精品一线二线三线无人区| 亚洲精品国久久99热| 国产精品白丝jk黑袜喷水| 久久精品论坛| 欧美电影免费观看高清| 一本色道久久综合狠狠躁篇的优点 | 黑人巨大精品欧美黑白配亚洲| 久久一日本道色综合久久| 免费在线欧美视频| 亚洲性感激情| 欧美一区二区三区免费视频| 一色屋精品视频在线看| 亚洲人成在线观看网站高清| 欧美日韩久久不卡| 久久久久久网址| 欧美大片在线观看一区| 欧美一区成人| 欧美顶级大胆免费视频| 亚洲一区三区视频在线观看 | 亚洲区欧美区| 国产精品一区二区男女羞羞无遮挡| 久久视频国产精品免费视频在线| 欧美成人午夜影院| 久久精品成人一区二区三区蜜臀| 欧美va亚洲va国产综合| 欧美亚洲在线观看| 欧美精品亚洲| 欧美激情精品久久久久久变态| 国产精品一区二区三区四区五区 | 欧美精品二区三区四区免费看视频| 中国成人亚色综合网站| 久久久久免费视频| 香蕉av福利精品导航| 欧美11—12娇小xxxx| 久久久久国产精品一区三寸| 欧美性事在线| 亚洲区国产区| 久久精品免费观看| 午夜精品久久久久99热蜜桃导演| 久久免费视频网| 久久精品国产一区二区电影| 欧美日韩亚洲综合在线| 亚洲国产精品久久人人爱蜜臀 | 亚洲视频久久| 亚洲人成网站色ww在线| 欧美一区二区三区播放老司机| 一区二区三区视频在线看| 欧美 亚欧 日韩视频在线| 免费毛片一区二区三区久久久| 国产午夜精品麻豆| 午夜亚洲福利| 久久av红桃一区二区小说| 国产精品一区视频网站| 在线综合视频| 午夜在线不卡| 国产情人综合久久777777| 亚洲一品av免费观看| 午夜国产一区| 国产美女精品| 欧美一区高清| 欧美高清视频在线观看| 亚洲第一精品夜夜躁人人躁| 久久综合一区| 亚洲欧洲日本一区二区三区| 日韩视频久久| 国产精品国产自产拍高清av| 亚洲一区一卡| 激情六月婷婷久久| 久久视频精品在线| 欧美mv日韩mv国产网站| 91久久久久久| 欧美日韩在线播放三区| 亚洲一区二区免费看| 欧美在线一二三四区| 在线成人av| 欧美激情久久久久| 99re6这里只有精品| 午夜精品久久久久久久99樱桃| 国产精品视频xxxx| 久久嫩草精品久久久久| 亚洲激情二区| 久久精品国产久精国产一老狼| 在线播放中文字幕一区| 欧美成人一区在线| 亚洲一区二区三区视频播放| 久久大逼视频| 亚洲日本va午夜在线电影| 国产精品免费观看视频| 久久这里有精品视频| 亚洲美女免费精品视频在线观看| 亚洲淫性视频| 亚洲国产高清一区| 国产精品黄页免费高清在线观看| 欧美一区二区成人| 亚洲激情成人在线| 久久爱www.| 日韩视频一区二区三区在线播放免费观看 | 亚洲国产精品电影| 国产精品theporn| 久久色中文字幕| 国产精品99久久久久久人| 久久精品欧美日韩| 国产女主播一区二区三区| 久久综合中文字幕| 亚洲图片在区色| 欧美风情在线观看| 欧美一级精品大片| 洋洋av久久久久久久一区| 黄色亚洲网站| 国产精品美女久久久久久2018 | 久久精品国产综合| 亚洲一区二区精品视频| 亚洲成人在线视频网站| 国产伦精品一区二区| 欧美精选午夜久久久乱码6080| 午夜视频一区在线观看| 在线一区观看| 亚洲精品中文字幕女同|