MVC(Model/View/Controller)模式是國外用得比較多的一種設(shè)計模式,好象最早是在Smaltalk中出現(xiàn)。MVC包括三類對象。Model是應(yīng)用對象,View是它在屏幕上的表示,Controller定義用戶界面對用戶輸入的響應(yīng)方式。 模型-視圖-控制器(MVC)是80年代Smalltalk-80出現(xiàn)的一種軟件設(shè)計模式,現(xiàn)在已經(jīng)被廣泛的使用。 1、模型(Model) 模型是應(yīng)用程序的主體部分。模型表示業(yè)務(wù)數(shù)據(jù),或者業(yè)務(wù)邏輯. 2、視圖(View) 視圖是應(yīng)用程序中用戶界面相關(guān)的部分,是用戶看到并與之交互的界面。 3、控制器(controller) 控制器工作就是根據(jù)用戶的輸入,控制用戶界面數(shù)據(jù)顯示和更新model對象狀態(tài)。 MVC 式的出現(xiàn)不僅實現(xiàn)了功能模塊和顯示模塊的分離,同時它還提高了應(yīng)用系統(tǒng)的可維護性、可擴展性、可移植性和組件的可復(fù)用性 早期的程序中,如果不注意對數(shù)功能和顯示的解耦合,常常會導(dǎo)致程序的復(fù)雜及難以維護。很多VB,Delphi等RAD程序都有這種問題。甚至現(xiàn)在的C#,Java有時候也會出現(xiàn)把業(yè)務(wù)邏輯寫在顯示模塊中的現(xiàn)象 管MVC設(shè)計模式很早就提出,但在Web項目的開發(fā)中引入MVC卻是步履維艱。主要原因:一是在早期的Web項目的開發(fā)中,程序語言和HTML的分離一直難以實現(xiàn)。CGI程序以字符串輸出的形式動態(tài)地生成HTML內(nèi)容。后來隨著腳本語言的出現(xiàn),前面的方式又被倒了過來,改成將腳本語言書寫的程序嵌入在HTML內(nèi)容中。這兩種方式有一個相同的不足之處即它們總是無法將程序語言和HTML分離。二是腳本語言的功能相對較弱,缺乏支持MVC設(shè)計模式的一些必要的技術(shù)基礎(chǔ)。直到基于J2EE的JSP Model 2問世時才得以改觀。它用JSP技術(shù)實現(xiàn)視圖的功能,用Servlet技術(shù)實現(xiàn)控制器的功能,用JavaBean技術(shù)實現(xiàn)模型的功能 JSP Model 1 與 JSP Model 2 SUN在JSP出現(xiàn)早期制定了兩種規(guī)范,稱為Model1和Model2。雖然Model2在一定程度上實現(xiàn)了MVC,但是它的應(yīng)用用并不盡如人意 JSP Model 1 JSP Model 2 model2 容易使系統(tǒng)出現(xiàn)多個Controller,并且對頁面導(dǎo)航的處理比較復(fù)雜 有些人覺得model2仍不夠好,于是Craig R. McClanahan 2000年5月提交了一個WEB framework給Java Community.這就是后來的Struts. 2001年7月,Struts1.0,正式發(fā)布。該項目也成為了Apache Jakarta的子項目之一 Struts 質(zhì)上就是在Model2的基礎(chǔ)上實現(xiàn)的一個MVC架構(gòu)。它只有一個中心控制器,他采用XML定制轉(zhuǎn)向的URL。采用Action來處理邏輯
創(chuàng)新互聯(lián)是一家專業(yè)提供宿豫企業(yè)網(wǎng)站建設(shè),專注與成都網(wǎng)站建設(shè)、網(wǎng)站設(shè)計、H5響應(yīng)式網(wǎng)站、小程序制作等業(yè)務(wù)。10年已為宿豫眾多企業(yè)、政府機構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)的建站公司優(yōu)惠進行中。
以下摘自:
MVC是三個單詞的縮寫,分別為: 模型(Model),視圖(View)和控制Controller)。 MVC模式的目的就是實現(xiàn)Web系統(tǒng)的職能分工。 Model層實現(xiàn)系統(tǒng)中的業(yè)務(wù)邏輯,通??梢杂肑avaBean或EJB來實現(xiàn)。 View層用于與用戶的交互,通常用JSP來實現(xiàn)。 Controller層是Model與View之間溝通的橋梁,它可以分派用戶的請求并選擇恰當(dāng)?shù)囊晥D以用于顯示,同時它也可以解釋用戶的輸入并將它們映射為模型層可執(zhí)行的操作。
MVC(Model View Controller)模型(model)-視圖(view)-控制器(controller)
MVC本來是存在于Deskt
op程序中的,M是指數(shù)據(jù)模型,V是指用戶界面,C則是控制器。使用MVC copyright: Apple Inc.
的目的是將M和V的實現(xiàn)代碼分離,從而使同一個程序可以使用不同的表現(xiàn)形式。比如一批統(tǒng)計數(shù)據(jù)你可以分別用柱狀圖、餅圖來表示。C存在的目的則是確保M和V的同步,一旦M改變,V應(yīng)該同步更新。
模型-視圖-控制器(MVC)是Xerox PARC在八十年代為編程語言Smalltalk-80發(fā)明的一種軟件設(shè)計模式,至今已被廣泛使用。最近幾年被推薦為Oracle旗下Sun公司Java EE平臺的設(shè)計模式,并且受到越來越多的使用 ColdFusion 和 PHP 的開發(fā)者的歡迎。模型-視圖-控制器模式是一個有用的工具箱,它有很多好處,但也有一些缺點。
MVC是一個設(shè)計模式,它強制性的使應(yīng)用程序的輸入、處理和輸出分開。使用MVC應(yīng)用程序被分成三個核心部件:模型、視圖、控制器。它們各自處理自己的任務(wù)。
視圖
視圖是用戶看到并與之交互的界面。對老式的Web應(yīng)用程序來說,視圖就是由HTML元素組成的界面,在新式的Web應(yīng)用程序中,HTML依舊在視圖中扮演著重要的角色,但一些新的技術(shù)已層出不窮,它們包括Macromedia Flash和象XHTML,XML/XSL,WML等一些標(biāo)識語言和Web services.
如何處理應(yīng)用程序的界面變得越來越有挑戰(zhàn)性。MVC一個大的好處是它能為你的應(yīng)用程序處理很多不同的視圖。在視圖中其實沒有真正的處理發(fā)生,不管這些數(shù)據(jù)是聯(lián)機存儲的還是一個雇員列表,作為視圖來講,它只是作為一種輸出數(shù)據(jù)并允許用戶操縱的方式。
模型
模型表示企業(yè)數(shù)據(jù)和業(yè)務(wù)規(guī)則。在MVC的三個部件中,模型擁有最多的處理任務(wù)。例如它可能用象EJBs和ColdFusion Components這樣的構(gòu)件對象來處理數(shù)據(jù)庫。被模型返回的數(shù)據(jù)是中立的,就是說模型與數(shù)據(jù)格式無關(guān),這樣一個模型能為多個視圖提供數(shù)據(jù)。由于應(yīng)用于模型的代碼只需寫一次就可以被多個視圖重用,所以減少了代碼的重復(fù)性。
控制器
控制器接受用戶的輸入并調(diào)用模型和視圖去完成用戶的需求。所以當(dāng)單擊Web頁面中的超鏈接和發(fā)送HTML表單時,控制器本身不輸出任何東西和做任何處理。它只是接收請求并決定調(diào)用哪個模型構(gòu)件去處理請求,然后再確定用哪個視圖來顯示返回的數(shù)據(jù)。
為什么要使用 MVC
大部分Web應(yīng)用程序都是用像ASP,PHP,或者CFML這樣的過程化(自PHP5.0版本后已全面支持面向?qū)ο竽P?語言來創(chuàng)建的。它們將像數(shù)據(jù)庫查詢語句這樣的數(shù)據(jù)層代碼和像HTML這樣的表示層代碼混在一起。經(jīng)驗比較豐富的開發(fā)者會將數(shù)據(jù)從表示層分離開來,但這通常不是很容易做到的,它需要精心的計劃和不斷的嘗試。MVC從根本上強制性的將它們分開。盡管構(gòu)造MVC應(yīng)用程序需要一些額外的工作,但是它給我們帶來的好處是毋庸置疑的。
首先,最重要的一點是多個視圖能共享一個模型,現(xiàn)在需要用越來越多的方式來訪問你的應(yīng)用程序。對此,其中一個解決之道是使用MVC,無論你的用戶想要Flash界面或是 WAP 界面;用一個模型就能處理它們。由于你已經(jīng)將數(shù)據(jù)和業(yè)務(wù)規(guī)則從表示層分開,所以你可以最大化的重用你的代碼了。 由于模型返回的數(shù)據(jù)沒有進行格式化,所以同樣的構(gòu)件能被不同界面使用。例如,很多數(shù)據(jù)可能用HTML來表示,但是它們也有可能要用Adobe Flash和WAP來表示。模型也有狀態(tài)管理和數(shù)據(jù)持久性處理的功能,例如,基于會話的購物車和電子商務(wù)過程也能被Flash網(wǎng)站或者無線聯(lián)網(wǎng)的應(yīng)用程序所重用。
因為模型是自包含的,并且與控制器和視圖相分離,所以很容易改變你的應(yīng)用程序的數(shù)據(jù)層和業(yè)務(wù)規(guī)則。如果你想把你的數(shù)據(jù)庫從MySQL移植到Oracle,或者改變你的基于RDBMS數(shù)據(jù)源到LDAP,只需改變你的模型即可。一旦你正確的實現(xiàn)了模型,不管你的數(shù)據(jù)來自數(shù)據(jù)庫或是LDAP服務(wù)器,視圖將會正確的顯示它們。由于運用MVC的應(yīng)用程序的三個部件是相互獨立,改變其中一個不會影響其它兩個,所以依據(jù)這種設(shè)計思想你能構(gòu)造良好的松耦合的構(gòu)件。
對我來說,控制器也提供了一個好處,就是可以使用控制器來聯(lián)接不同的模型和視圖去完成用戶的需求,這樣控制器可以為構(gòu)造應(yīng)用程序提供強有力的手段。給定一些可重用的模型和視圖,控制器可以根據(jù)用戶的需求選擇模型進行處理,然后選擇視圖將處理結(jié)果顯示給用戶。
MVC的缺點是由于它沒有明確的定義,所以完全理解MVC并不是很容易。使用MVC需要精心的計劃,由于它的內(nèi)部原理比較復(fù)雜,所以需要花費一些時間去思考。
你將不得不花費相當(dāng)可觀的時間去考慮如何將MVC運用到你的應(yīng)用程序,同時由于模型和視圖要嚴(yán)格的分離,這樣也給調(diào)試應(yīng)用程序帶來了一定的困難。每個構(gòu)件在使用之前都需要經(jīng)過徹底的測試。一旦你的構(gòu)件經(jīng)過了測試,你就可以毫無顧忌的重用它們了。
根據(jù)開發(fā)者經(jīng)驗,由于開發(fā)者將一個應(yīng)用程序分成了三個部件,所以使用MVC同時也意味著你將要管理比以前更多的文件,這一點是顯而易見的。這樣好像我們的工作量增加了,但是請記住這比起它所能帶給我們的好處是不值一提。
MVC并不適合小型甚至中等規(guī)模的應(yīng)用程序,花費大量時間將MVC應(yīng)用到規(guī)模并不是很大的應(yīng)用程序通常會得不償失。
MVC設(shè)計模式是一個很好創(chuàng)建軟件的途徑,它所提倡的一些原則,像內(nèi)容和顯示互相分離可能比較好理解。但是如果你要隔離模型、視圖和控制器的構(gòu)件,你可能需要重新思考你的應(yīng)用程序,尤其是應(yīng)用程序的構(gòu)架方面。如果你肯接受MVC,并且有能力應(yīng)付它所帶來的額外的工作和復(fù)雜性,MVC將會使你的軟件在健壯性,代碼重用和結(jié)構(gòu)方面上一個新的臺階。
MVC全名是Model View Controller,是模型(model)-視圖(view)-控制器(controller)的縮寫,一種軟件設(shè)計典范,用一種業(yè)務(wù)邏輯、數(shù)據(jù)、界面顯示分離的方法組織代碼,將業(yè)務(wù)邏輯聚集到一個部件里面,在改進和個性化定制界面及用戶交互的同時,不需要重新編寫業(yè)務(wù)邏輯。
MVC被獨特的發(fā)展起來用于映射傳統(tǒng)的輸入、處理和輸出功能在一個邏輯的圖形化用戶界面的結(jié)構(gòu)中。
MVC開始是存在于桌面程序中的,M是指業(yè)務(wù)模型,V是指用戶界面,C則是控制器,使用MVC的目的是將M和V的實現(xiàn)代碼分離,從而使同一個程序可以使用不同的表現(xiàn)形式。
比如一批統(tǒng)計數(shù)據(jù)可以分別用柱狀圖、餅圖來表示。C存在的目的則是確保M和V的同步,一旦M改變,V應(yīng)該同步更新。
模型-視圖-控制器(MVC)是Xerox PARC在二十世紀(jì)八十年代為編程語言Smalltalk-80發(fā)明的一種軟件設(shè)計模式,已被廣泛使用。
后來被推薦為Oracle旗下Sun公司Java EE平臺的設(shè)計模式,并且受到越來越多的使用ColdFusion和PHP的開發(fā)者的歡迎。模型-視圖-控制器模式是一個有用的工具箱,它有很多好處,但也有一些缺點。
擴展資料:
MVC 編程模式:
MVC 是一種使用 MVC(Model View Controller 模型-視圖-控制器)設(shè)計創(chuàng)建 Web 應(yīng)用程序的模式:
1、Model(模型)表示應(yīng)用程序核心(比如數(shù)據(jù)庫記錄列表)。
2、View(視圖)顯示數(shù)據(jù)(數(shù)據(jù)庫記錄)。
3、Controller(控制器)處理輸入(寫入數(shù)據(jù)庫記錄)
MVC 模式同時提供了對 HTML、CSS 和 JavaScript 的完全控制:
1、Model(模型)是應(yīng)用程序中用于處理應(yīng)用程序數(shù)據(jù)邏輯的部分。
通常模型對象負(fù)責(zé)在數(shù)據(jù)庫中存取數(shù)據(jù)。
2、View(視圖)是應(yīng)用程序中處理數(shù)據(jù)顯示的部分。
通常視圖是依據(jù)模型數(shù)據(jù)創(chuàng)建的。
3、Controller(控制器)是應(yīng)用程序中處理用戶交互的部分。
通常控制器負(fù)責(zé)從視圖讀取數(shù)據(jù),控制用戶輸入,并向模型發(fā)送數(shù)據(jù)。
MVC 分層有助于管理復(fù)雜的應(yīng)用程序,因為您可以在一個時間內(nèi)專門關(guān)注一個方面。例如,您可以在不依賴業(yè)務(wù)邏輯的情況下專注于視圖設(shè)計。同時也讓應(yīng)用程序的測試更加容易。
MVC 分層同時也簡化了分組開發(fā)。不同的開發(fā)人員可同時開發(fā)視圖、控制器邏輯和業(yè)務(wù)邏輯。
框架內(nèi)容:
MVC指MVC模式的某種框架,它強制性的使應(yīng)用程序的輸入、處理和輸出分開。使用MVC應(yīng)用程序被分成三個核心部件:模型、視圖、控制器。它們各自處理自己的任務(wù)。最典型的MVC就是JSP + servlet + javabean的模式。
1、視圖
視圖是用戶看到并與之交互的界面。對老式的Web應(yīng)用程序來說,視圖就是由HTML元素組成的界面,在新式的Web應(yīng)用程序中,HTML依舊在視圖中扮演著重要的角色,但一些新的技術(shù)已層出不窮,它們包括Adobe Flash和像XHTML,XML/XSL,WML等一些標(biāo)識語言和Web services.
MVC好處是它能為應(yīng)用程序處理很多不同的視圖。在視圖中其實沒有真正的處理發(fā)生,不管這些數(shù)據(jù)是聯(lián)機存儲的還是一個雇員列表,作為視圖來講,它只是作為一種輸出數(shù)據(jù)并允許用戶操縱的方式。
2、模型
模型表示企業(yè)數(shù)據(jù)和業(yè)務(wù)規(guī)則。在MVC的三個部件中,模型擁有最多的處理任務(wù)。
例如它可能用像EJBs和ColdFusion Components這樣的構(gòu)件對象來處理數(shù)據(jù)庫,被模型返回的數(shù)據(jù)是中立的,就是說模型與數(shù)據(jù)格式無關(guān),這樣一個模型能為多個視圖提供數(shù)據(jù),由于應(yīng)用于模型的代碼只需寫一次就可以被多個視圖重用,所以減少了代碼的重復(fù)性。
3、控制器
控制器接受用戶的輸入并調(diào)用模型和視圖去完成用戶的需求,所以當(dāng)單擊Web頁面中的超鏈接和發(fā)送HTML表單時,控制器本身不輸出任何東西和做任何處理。它只是接收請求并決定調(diào)用哪個模型構(gòu)件去處理請求,然后再確定用哪個視圖來顯示返回的數(shù)據(jù)。
常見框架Struts:
Struts是Apache軟件基金下Jakarta項目的一部分。Struts框架的主要架構(gòu)設(shè)計和開發(fā)者是Craig R.McClanahan。Struts 是Java Web MVC框架中不爭的王者。經(jīng)過長達九年的發(fā)展,Struts已經(jīng)逐漸成長為一個穩(wěn)定、成熟的框架,并且占有了MVC框架中最大的市場份額。
但是Struts某些技術(shù)特性上已經(jīng)落后于新興的MVC框架。面對Spring MVC、Webwork2這些設(shè)計更精密,擴展性更強的框架,Struts受到了前所未有的挑戰(zhàn)。但站在產(chǎn)品開發(fā)的角度而言,Struts仍然是最穩(wěn)妥的選擇。
Struts有一組相互協(xié)作的類(組件)、Servlet以及jsp tag lib組成。基于struts構(gòu)架的web應(yīng)用程序基本上符合JSP Model2的設(shè)計標(biāo)準(zhǔn),可以說是MVC設(shè)計模式的一種變化類型。
根據(jù)上面對framework的描述,很容易理解為什么說Struts是一個web framework,而不僅僅是一些標(biāo)記庫的組合。但 Struts 也包含了豐富的標(biāo)記庫和獨立于該框架工作的實用程序類。
Struts有其自己的控制器(Controller),同時整合了其他的一些技術(shù)去實現(xiàn)模型層(Model)和視圖層(View)。
在模型層,Struts可以很容易的與數(shù)據(jù)訪問技術(shù)相結(jié)合,包括EJB,JDBC和Object Relation Bridge。在視圖層,Struts能夠與JSP, Velocity Templates,XSL等等這些表示層組件相結(jié)合。
參考資料:
百度百科-MVC框架
MVC架構(gòu)是交互式應(yīng)用中廣泛使用的架構(gòu)。它將對象按功能進行劃分,盡可能地最小化對象之間的耦合度。MVC架構(gòu)與傳統(tǒng)的應(yīng)用程序架構(gòu)—輸入,處理,輸出給用戶接口的模型相對應(yīng)。它們也與基于域的多層企業(yè)級WEB應(yīng)用相對應(yīng)。
MVC架構(gòu)將應(yīng)用分為三層—模型,視圖,控制,并減弱它們各自的責(zé)任。每一層處理特定的任務(wù)并對其它層有特殊的責(zé)任。
A. 模型存儲業(yè)務(wù)數(shù)據(jù)和控制訪問與修改業(yè)務(wù)數(shù)據(jù)的業(yè)務(wù)邏輯或操作。表現(xiàn)上看,模型與軟件中的函數(shù)功能有些相似。當(dāng)模型改變時會通知視圖并為視圖提供了查詢模型狀態(tài)的能力。它也為控制器提供了訪問封裝在模型中的應(yīng)用功能函數(shù)的能力。
B. 視圖展示模型中的內(nèi)容。它訪問模型中的數(shù)據(jù)并完成數(shù)據(jù)的顯示工作。當(dāng)模型改變時它會即時更新數(shù)據(jù)的展示。視圖也完成將用戶的輸入傳遞到控制器的功能。
C. 控制器定義了應(yīng)用程序的行為。它分派用戶的請求然后調(diào)用相應(yīng)的視圖來展示。它解析用戶的輸入然后與模型中完成相應(yīng)功能的事件處理相匹配。在標(biāo)準(zhǔn)的GUI客戶端應(yīng)用中,用戶輸入包括點擊按鈕和選擇菜單。在WEB應(yīng)用中,它們則是WEB層中的HTTP GET和POST請求。控制器選擇相應(yīng)的視圖來顯示是基于用戶與模型相互交互的結(jié)果。一個典型的應(yīng)用是所有相關(guān)的功能由一個控制器來處理。一些應(yīng)用針對不同的客戶端類型采用不同的控制器來處理,因為視圖的交互與選擇可能因客戶端類型的不同而有所不同。
MVC(模型Model-視圖View-控制器Controller)是一種設(shè)計模式,
MVC。V即View.是視圖的意思。C即Controller.是控制器的意思。而M即Model,是模型的意思。這三個里.最不容易理解的應(yīng)該是Model.就是什么是Model,而為什么叫Model。我先不說為什么叫Model,先解釋Controller。
Controller是控制器的意思,所謂控制器,就是將用戶請求轉(zhuǎn)發(fā)給模型層,經(jīng)過處理后把結(jié)果返回到界面層展現(xiàn)的一個中間層,那么Controller到底管什么工作呢?先不說.先來看下在Java
Web中這三個層一般的定義,一般在Java
Web里,JSP充當(dāng)V,Servlet充當(dāng)C,JavaBean充當(dāng)M,這里的Servlet管什么工作呢?接受輸入,轉(zhuǎn)到Model層去處理,處理結(jié)果保存后轉(zhuǎn)發(fā)到JSP,然后展現(xiàn)數(shù)據(jù)。所以它的功能就是控制器的基本功能,它就管轉(zhuǎn)發(fā),在V和M之間轉(zhuǎn)來轉(zhuǎn)去。
再來說說M,即Model,在Java
Web里說的是JavaBean,我認(rèn)識的很多人都把JavaBean誤認(rèn)為是實體類,其實JavaBean有比實體類更豐富的定義,在JavaBean中除了其屬性和字段,還可以有行為及其事件,JavaBean可以理解為普通Java對象。Java普通對象,就是符合Java規(guī)范的所有對象,這和實體類完全是兩回事。所以,我認(rèn)為在MVC中。業(yè)務(wù)邏輯和數(shù)據(jù)訪問應(yīng)該放在Model層,也就是V負(fù)責(zé)展示數(shù)據(jù),Controler除了轉(zhuǎn)發(fā)不做業(yè)務(wù)邏輯。真正的邏輯事務(wù),數(shù)據(jù)訪問,甚至算法都放到Model去。
MVC沒有把業(yè)務(wù)的邏輯訪問看成兩個層,這是采用三層架構(gòu)或MVC搭建程序最主要的區(qū)別。當(dāng)然了。在三層中也提到了Model,但是三層架構(gòu)中Model的概念與MVC中Model的概念是不一樣的,“三層”中典型的Model層是已實體類構(gòu)成的,而MVC里,則是由業(yè)務(wù)邏輯與訪問數(shù)據(jù)組成的
什么是MVP
View:是指顯示數(shù)據(jù)并且和用戶交互的層。在安卓中,它們可以是一個Activity,一個Fragment,一個android.view.View或者是一個Dialog。
Model:是數(shù)據(jù)源層。比如數(shù)據(jù)庫接口或者遠程服務(wù)器的api。
Presenter:是從Model中獲取數(shù)據(jù)并提供給View的層,Presenter還負(fù)責(zé)處理后臺任務(wù)。
MVP是一個將后臺任務(wù)和activities/views/fragment分離的方法,讓它們獨立于絕大多數(shù)跟生命周期相關(guān)的事件。這樣應(yīng)用就會變得更簡單,整個應(yīng)用的穩(wěn)定性提高10倍以上,代碼也變得更短,可維護性增強,程序員也不會過勞死了~~。
為什么要在安卓上使用MVP原因一:盡量簡單
如果你還沒有閱讀過這篇文章,閱讀它:Kiss原則()。-kiss是KeepItStupidSimple或者KeepItSimple,Stupid的縮寫。
.絕大多數(shù)的安卓程序都只使用了View-Model架構(gòu)。
.程序員被絞盡了復(fù)雜的界面開發(fā)中,而不是解決事務(wù)邏輯。
在應(yīng)用中使用Model-View的壞處是“每個東西之間都是相互關(guān)聯(lián)的”如下圖:
如果上面的圖解看起來還不夠復(fù)雜,那么想想這些情況:每個view可能在任意的時間出現(xiàn)或者消失,view數(shù)據(jù)需要保存與恢復(fù),在臨時的view上掛載一個后臺任務(wù)。
而與“每個東西之間都是相互關(guān)聯(lián)的”的相反選擇是使用一個萬能對象(godobject)。注:godobject是指一個對象/例程在系統(tǒng)中做了太多的事情,或者說是有太多不怎么相關(guān)的事情放在一個對象/例程里面來完成。
godobject過于復(fù)雜,他的不同部分無法重用、測試,無法輕易的debug和重構(gòu)。
使用MVP
復(fù)雜的任務(wù)被分割成簡單的任務(wù)。
.更小的對象,更少的bug。
.更好測試
MVP的view層變得如此簡單,在請求數(shù)據(jù)的時候甚至不需要使用回調(diào)。view的邏輯變得非常直接。
原因二:后臺任務(wù)
當(dāng)你需要寫一個Activity,F(xiàn)ragment或者一個自定義View的時候,你可以將所有和后臺任務(wù)相關(guān)的方法放在一個外部的或者靜態(tài)的類中。這樣你的后臺任務(wù)就不會再與Activity相關(guān)聯(lián),不會在泄漏內(nèi)存同時也不會依賴于Activity的重建。我們稱這樣的一個類為“Presenter”。注:要理解此話的含義最好先看懂第一個MVP示例的代碼。
雖然有一些方法可以解決后臺任務(wù)的問題,但是沒有一種和MVP一樣可靠。
為什么這是可行的
下面的圖解顯示了在configuration改變或者發(fā)生out-of-memory事件的情況下應(yīng)用的不同部分所發(fā)生的事情。每一個開發(fā)者都應(yīng)該知道這些數(shù)據(jù),但是這些數(shù)據(jù)并不好發(fā)現(xiàn)。
|??Case1??|?Case2??|??Case3
|Aconfiguration|Anactivity?|?Aprocess
|?change???|?restart??|?restart
----------------------------------------|-------------|------------|------------
Dialog?????????????????|??reset??|??reset??|??reset
Activity,View,Fragment????????|save/restore?|save/restore|save/restore
FragmentwithsetRetainInstance(true)??|?nochange?|save/restore|save/restore
Staticvariablesandthreads??????|?nochange?|?nochange?|??reset
情景1:configuration的改變通常發(fā)生在旋轉(zhuǎn)屏幕,修改語言設(shè)置,鏈接外部的模擬器等情況下。要知道更多的configurationchange事件請閱讀:configChanges(developer.android.com/reference/android/R.attr.html#configChanges)。
情景2:Activity的重啟發(fā)生在當(dāng)用戶在開發(fā)者選項中選中了“Don'tkeepactivities”(“中文下為不保留活動”)的復(fù)選框,然后另一個Activity在最頂上的時候。
情景3:進程的重啟發(fā)生在應(yīng)用運行在后臺,但是這個時候內(nèi)存不夠的情況下。
結(jié)論
現(xiàn)在你可以發(fā)現(xiàn),一個擁有setRetainInstance(true)的Fragment并沒有帶來幫助-我們還是要保存和/恢復(fù)這種fragment的狀態(tài)。因此我們可以去掉可保持Fragment的情景,把問題簡單化。Occam'srazor()