兩張圖看懂Android開發(fā)中MVC與MVP的區(qū)別

看了很多文章,沒有很好的文章能簡(jiǎn)明扼要的說清楚Android開發(fā)中MVC和MVP的區(qū)別咕村。MVC很早就出來了发笔,之前廣泛用于JavaWeb開發(fā)中陈轿,MVC也可以用來開發(fā)Android劳淆,但是有些水土不服链沼!

1、MVC結(jié)構(gòu)示意圖

這里寫圖片描述

------------- 點(diǎn)擊打開大圖 -------------

2沛鸵、MVP結(jié)構(gòu)示意圖

這里寫圖片描述

------------- 點(diǎn)擊打開大圖 -------------

好用的在線UML工具:https://www.processon.com/

2括勺、MVP與MVC的區(qū)別(閱讀時(shí)請(qǐng)不斷對(duì)比上面的兩張圖)

  1. Activity職責(zé)不同,Activity在MVP中是View層曲掰,在MVC中是Controller層疾捍,這是MVC和MVP很主要的一個(gè)區(qū)別,可以說Android從MVC轉(zhuǎn)向MVP開發(fā)也主要是優(yōu)化Activity的代碼栏妖,避免Activity的代碼臃腫龐大乱豆。

  2. View層不同,MVC的View層指的是XML布局文件或者是用Java自定義的View吊趾,MVP的View層是Activity或者Fragment宛裕。使用傳統(tǒng)的MVC,其中的View论泛,對(duì)應(yīng)的是各種Layout布局文件揩尸,但是這些布局文件中并不像Web端那樣強(qiáng)大,能做的事情非常有限屁奏。MVP的View層Activity在實(shí)際項(xiàng)目中岩榆,隨著邏輯的復(fù)雜度越來越大,Activity臃腫的缺點(diǎn)仍然體現(xiàn)出來了坟瓢,因?yàn)锳ctivity中還是充滿了大量與View層無關(guān)的代碼勇边,比如各種事件的處理派發(fā),就如MVC中的那樣View層和Controller代碼耦合在一起無法自拔载绿。

  3. 控制層不同粥诫,MVC的控制層是Activity油航,或者是Fragment崭庸,Controller對(duì)應(yīng)的是Activity,而Activity中卻又具有操作UI的功能谊囚,我們?cè)趯?shí)際的項(xiàng)目中也會(huì)有很多UI操作在這一層怕享,也做了很多View中應(yīng)該做的事情,當(dāng)然Controller層Activity中也包含Controller應(yīng)該做的事情镰踏,比如各種事件的派發(fā)回調(diào)函筋,而且在一層中我們會(huì)根據(jù)事件再去調(diào)用Model層操作數(shù)據(jù),所以這種MVC的方式在實(shí)際項(xiàng)目中奠伪,Activity所在的Controller是非常重的跌帐,各層次之間的耦合情況也比較嚴(yán)重首懈,不方便單元測(cè)試。MVP的控制層是Presenter谨敛,里面沒有很多的實(shí)際東西究履,主要是做Model和View層的交互。

  4. 關(guān)系鏈不同脸狸,MVP中Model層與View是沒有關(guān)系的最仑,彼此不會(huì)通訊和操作,Model與View的通訊都是Presenter層來傳達(dá)的炊甲。但是在MVC中泥彤,Model層和View是曾在交互的。比如我們自定義的View控件里面肯定是要使用Model的數(shù)據(jù)的卿啡,View也要根據(jù)不同的Model數(shù)據(jù)做出不同的展現(xiàn)吟吝!這點(diǎn)尤其是體現(xiàn)在自定義的View中,自定義View需要設(shè)置數(shù)據(jù)颈娜,用戶操作了自定義控件需要改變數(shù)據(jù)爸黄,View要操作Model怎么辦?有人說把Controller傳到自定義的View啊揭鳞,現(xiàn)實(shí)是不可能沒一個(gè)自定義View都去持有Controller的引用炕贵,其實(shí)在MVP中就不會(huì)這么尷尬,接口就可以完成野崇。

  5. 適用范圍不同称开,在Android中,MVP和MVC都用自己的適用情況乓梨,使用MVP可以更好的解耦三大模塊鳖轰,模塊之間比較清晰,也很方便使用MVP來組件化架構(gòu)整體項(xiàng)目扶镀。但是MVC也是有用武之地的蕴侣,在組件化的Module或者中間件我們可以使用MVC來做,Module或者中間件不會(huì)存在很復(fù)雜的View層臭觉,使用MVC可以更加方便我們實(shí)現(xiàn)功能昆雀。

  6. 交互方式不同,MVP中通訊交互基本都是通過接口的蝠筑,MVC中的通訊交互很多時(shí)候都是實(shí)打?qū)嵉恼{(diào)用對(duì)象的方法狞膘,簡(jiǎn)單粗暴!

  7. 實(shí)現(xiàn)方法不同 什乙,MVC和MVP的Model幾乎一樣的挽封,都是處理數(shù)據(jù),只要不在Activity或者Fragment中請(qǐng)求數(shù)據(jù)臣镣,其他的所有控制都放在Activity或者Fragment中辅愿,這樣寫就基本是MVC的模式智亮,這樣寫不麻煩,但是很容易把Activity寫出上萬行代碼点待。用MVP的時(shí)候我們需要寫很多View和Presenter接口來實(shí)現(xiàn)模塊之間的通訊鸽素,會(huì)增加很多類。

網(wǎng)絡(luò)流行對(duì)比段子:

(1)相同點(diǎn):
優(yōu)點(diǎn):
1.降低耦合度
2.模塊職責(zé)劃分明顯
3.利于測(cè)試驅(qū)動(dòng)開發(fā)
4.代碼復(fù)用
5.隱藏?cái)?shù)據(jù)
6.代碼靈活性
缺點(diǎn):
額外的代碼復(fù)雜度及學(xué)習(xí)成本亦鳞。

(2)不同點(diǎn):
MVP模式:
1.View不直接與Model交互馍忽,而是通過與Presenter交互來與Model間接交互
2.Presenter與View的交互是通過接口來進(jìn)行的,更有利于添加單元測(cè)試
3.通常View與Presenter是一對(duì)一的燕差,但復(fù)雜的View可能綁定多個(gè)Presenter來處理邏輯遭笋,業(yè)務(wù)相似的時(shí)候也可以多同個(gè)View共享一個(gè)Presenter。
MVC模式:
1.View可以與Model直接交互
2.Controller是基于行為的徒探,并且可以被多個(gè)View共享
3.Controller可以負(fù)責(zé)決定顯示哪個(gè)View

不管Activity在MVP中是View層瓦呼,還是Activity在MVC中是Controller層,都無法避免Activity的代碼量越來越大测暗。我們可以根據(jù)項(xiàng)目的實(shí)際情況盡量?jī)?yōu)化央串,MVP和MVC只是一種編碼思想,再說再牛逼的架構(gòu)都抵不過產(chǎn)品的傻逼需求碗啄!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末质和,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子稚字,更是在濱河造成了極大的恐慌饲宿,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,755評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件胆描,死亡現(xiàn)場(chǎng)離奇詭異瘫想,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)昌讲,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,305評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門国夜,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人短绸,你說我怎么就攤上這事车吹。” “怎么了鸠按?”我有些...
    開封第一講書人閱讀 165,138評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵礼搁,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我目尖,道長(zhǎng),這世上最難降的妖魔是什么扎运? 我笑而不...
    開封第一講書人閱讀 58,791評(píng)論 1 295
  • 正文 為了忘掉前任瑟曲,我火速辦了婚禮饮戳,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘洞拨。我一直安慰自己扯罐,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,794評(píng)論 6 392
  • 文/花漫 我一把揭開白布烦衣。 她就那樣靜靜地躺著歹河,像睡著了一般。 火紅的嫁衣襯著肌膚如雪花吟。 梳的紋絲不亂的頭發(fā)上秸歧,一...
    開封第一講書人閱讀 51,631評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音衅澈,去河邊找鬼键菱。 笑死,一個(gè)胖子當(dāng)著我的面吹牛今布,可吹牛的內(nèi)容都是我干的经备。 我是一名探鬼主播,決...
    沈念sama閱讀 40,362評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼部默,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼侵蒙!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起傅蹂,我...
    開封第一講書人閱讀 39,264評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤蘑志,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后贬派,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體急但,經(jīng)...
    沈念sama閱讀 45,724評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,900評(píng)論 3 336
  • 正文 我和宋清朗相戀三年搞乏,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了波桩。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,040評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡请敦,死狀恐怖镐躲,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情侍筛,我是刑警寧澤萤皂,帶...
    沈念sama閱讀 35,742評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站匣椰,受9級(jí)特大地震影響裆熙,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,364評(píng)論 3 330
  • 文/蒙蒙 一入录、第九天 我趴在偏房一處隱蔽的房頂上張望蛤奥。 院中可真熱鬧,春花似錦僚稿、人聲如沸凡桥。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,944評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽缅刽。三九已至,卻和暖如春蠢络,著一層夾襖步出監(jiān)牢的瞬間衰猛,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,060評(píng)論 1 270
  • 我被黑心中介騙來泰國(guó)打工谢肾, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留腕侄,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,247評(píng)論 3 371
  • 正文 我出身青樓芦疏,卻偏偏與公主長(zhǎng)得像冕杠,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子酸茴,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,979評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容