Android 應(yīng)用架構(gòu)概述

通常一個(gè)App的成長(zhǎng)過(guò)程都是這樣的:

第一階:先用最少的成本和時(shí)間快速把東西做出來(lái)侨糟。

第二階段:積累一定用戶(hù)量之后再小步快跑的迭代功能联四。

第三階段:性能和體驗(yàn)上逐步求精扰才。

我發(fā)現(xiàn)好多項(xiàng)目在第二階段和第三階段耗費(fèi)了好多本來(lái)不應(yīng)該浪費(fèi)的人力成本雄右、時(shí)間成本剃诅。究其原因就是因?yàn)榍捌诤雎粤撕侠淼募軜?gòu)巷送,我甚至經(jīng)歷過(guò)因?yàn)榍捌诘脑O(shè)計(jì)不合理導(dǎo)致后期技術(shù)債務(wù)太多項(xiàng)目瀕臨死掉、整個(gè)項(xiàng)目組全員換掉重造鍋爐的境地矛辕。所以笑跛,我們?yōu)槭裁床患饶苁褂米詈?jiǎn)潔的方式實(shí)現(xiàn)功又能要保證后期靈活的擴(kuò)展能力呢?下面是本人最近項(xiàng)目實(shí)踐的一些整理聊品,拋磚引玉飞蹂,希望一起討論。文章首發(fā):http://www.liuguangli.win/archives/299翻屈。

視圖和數(shù)據(jù)

好的代碼一定是層次分明陈哑、職責(zé)分明,糟糕的代碼架構(gòu)就是沒(méi)有層次沒(méi)有模塊伸眶,每次修改代碼都是牽一發(fā)動(dòng)全身芥颈。從大的方面來(lái)講Android應(yīng)用都會(huì)被分為兩層:視圖層、數(shù)據(jù)層赚抡。

數(shù)據(jù)和視圖

視圖:一般以Activity為依托的各種View,包含View纠屋、ViewGroup和WebView涂臣,還有各種fragment。

數(shù)據(jù):支撐整個(gè)應(yīng)用邏輯的數(shù)據(jù)售担,分為兩類(lèi)赁遗。一類(lèi)存儲(chǔ)在遠(yuǎn)端服務(wù)器上的,一類(lèi)在本地族铆。遠(yuǎn)端數(shù)據(jù)需要通過(guò)網(wǎng)絡(luò)(通常是Http)獲取岩四,本地?cái)?shù)據(jù)包括sqlite存儲(chǔ)的關(guān)系型數(shù)據(jù),文件系統(tǒng)哥攘,內(nèi)存緩存對(duì)象剖煌。

必然聯(lián)系

用數(shù)據(jù)驅(qū)動(dòng)視圖變化材鹦,這才產(chǎn)生了豐富多彩的應(yīng)用交互世界,所以耕姊,視圖和數(shù)據(jù)的聯(lián)系是必然的桶唐。

視圖數(shù)據(jù)的直接聯(lián)系

在Android平臺(tái)和整個(gè)移動(dòng)開(kāi)發(fā)生態(tài)都發(fā)展的非常快茉兰,在Android興起之初尤泽,對(duì)層的重要性不是太強(qiáng)調(diào),所有很多開(kāi)始寫(xiě)Android程序的開(kāi)發(fā)對(duì)層劃分不是太清晰 规脸,看到很多入門(mén)書(shū)本里很多直接在Activity里面直接處理數(shù)據(jù)的代碼坯约,例如直接在Activity里面直接調(diào)SharedPrefrence操作數(shù)據(jù),直接在Activity 里面直接調(diào)用網(wǎng)絡(luò)請(qǐng)求等莫鸭,很多初級(jí)選手的很容易寫(xiě)出這樣沒(méi)有層次的代碼出來(lái)闹丐。當(dāng)接口變更,當(dāng)存儲(chǔ)方式更好的時(shí)候整個(gè)UI層面的邏輯都受影響黔龟。

解耦

好一點(diǎn)的設(shè)計(jì)必然會(huì)做一次隔離:盡量做到UI和數(shù)據(jù)彼此透明妇智、“互不干涉內(nèi)政”。

解耦

隔離的好處是:一氏身、 提高可維護(hù)性巍棱。在UI邏輯發(fā)生變化甚至整個(gè)端掉都不會(huì)影響到處理邏輯。二蛋欣、 提高可復(fù)用性航徙。復(fù)用通常只數(shù)據(jù)的復(fù)用,數(shù)據(jù)邏輯不受UI的左右陷虎,由此可以服務(wù)于多個(gè)UI視圖到踏。三、 可讀性尚猿。層次分清之后按照統(tǒng)一的架構(gòu)思路去理解代碼窝稿,當(dāng)然還得靠開(kāi)發(fā)人員良好的編程素養(yǎng)和代碼規(guī)范。

那么怎么做到隔離呢凿掂?關(guān)于解耦伴榔,業(yè)內(nèi)比統(tǒng)一的可以歸納為兩種:MVC、MVP(MVVM)庄萎。

MVC解耦

mvc

V:在MVC架構(gòu)中Activity(托管Fragment踪少,View,WebView等)首先充當(dāng)V的角色糠涛。

M:業(yè)務(wù)邏輯層劃分出來(lái)專(zhuān)門(mén)處理數(shù)據(jù)援奢。例如:數(shù)據(jù)的http請(qǐng)求,數(shù)據(jù)解析和儲(chǔ)存等邏輯都封裝在這一層忍捡。Activity不直接和Http集漾,Dao(數(shù)據(jù)訪問(wèn)對(duì)象層)直接有聯(lián)系了切黔,視圖數(shù)據(jù)從此為路人。

C:C是什么帆竹?MVC這個(gè)模式及概念绕娘,在移動(dòng)應(yīng)用開(kāi)發(fā)出新之前就已經(jīng)產(chǎn)生了,最經(jīng)典的水用場(chǎng)景JSP +servlet+javabean栽连,我開(kāi)始接觸MVC也是在做JavaWeb開(kāi)發(fā)的時(shí)候险领。后來(lái)Android開(kāi)發(fā)火了,把這套模式搬上來(lái)秒紧。但是C套上了不太好理解绢陌。Android應(yīng)用開(kāi)發(fā)中,套上MVC熔恢,Activity 兼具V和C的角色脐湾。

MVP解耦

很多時(shí)候視圖層面還是充斥中很多復(fù)雜的邏輯,例如UI事件的響應(yīng)處理叙淌,網(wǎng)絡(luò)響應(yīng)的回調(diào)等等秤掌,充斥著各種監(jiān)聽(tīng)器的回調(diào)。我們期望視圖V便當(dāng)更簡(jiǎn)單鹰霍、更純粹闻鉴,V只負(fù)責(zé)繪制和刷新其他邏輯都不用管了,也不想和M有直接的聯(lián)系茂洒。從MVC的VC(Activity)中我們分離一層出來(lái)叫做Presenter孟岛,由它來(lái)負(fù)責(zé)調(diào)度UI何時(shí)刷新、由它來(lái)接受UI的事件響應(yīng)并傳達(dá)指令給M督勺。從此V和M是路人渠羞,V和數(shù)據(jù)的距離跟遠(yuǎn)了。

mvp

V:Activity為代表智哀,這時(shí)候的Activity更為簡(jiǎn)單了次询,只負(fù)責(zé)UI的繪制和刷新。

P:負(fù)責(zé)傳達(dá)指令瓷叫。向上接收V的事件指令并需要的時(shí)候傳達(dá)給M渗蟹,向下接收M的指令并通知V刷新UI。

M:只負(fù)責(zé)出來(lái)數(shù)據(jù)邏輯赞辩。其實(shí)還可以細(xì)分一些東西,比如Http請(qǐng)求授艰,很多時(shí)候我們的Http框架都是用的第三方開(kāi)源框架辨嗽,如果有一天更優(yōu)秀的框架出現(xiàn)了,要更換淮腾,怎么才能做到不影響其他層次糟需?如果我門(mén)做了分層隔離那么屉佳,我門(mén)可以很輕松的換掉,如果沒(méi)有做分層隔離洲押,那么我門(mén)可能要在每一個(gè)功能模塊的M中修改代碼武花,修改代價(jià)是巨大的,所以一遍第三方開(kāi)源框架我都不會(huì)直接使用而是在業(yè)務(wù)上做一層抽象隔離杈帐。同理体箕,本地?cái)?shù)據(jù)的存儲(chǔ),也有必要做響應(yīng)的封裝或隔離挑童,因?yàn)榻裉焓怯肔itepal累铅,也許某一天想用GreenDao了,只需要修改封裝類(lèi)的代碼就好了站叼。

MVP的依賴(lài)關(guān)系:

MVP依賴(lài)關(guān)系

MVP類(lèi)圖:

MVP類(lèi)圖

我們把每一層都抽象成一個(gè)接口娃兽,例如V層,我們定義一個(gè)接口為View(不要和Android API里的View弄混了)尽楔,讓后Activity成為這個(gè)View的具體實(shí)現(xiàn)投储。每一層對(duì)另一層的依賴(lài)都是接口依賴(lài),并不關(guān)心另一層的具體實(shí)現(xiàn)阔馋,每一層我們都可以寫(xiě)不同的實(shí)現(xiàn)玛荞,隨時(shí)切換,這就意味著垦缅,有一天如果有一層不好用了冲泥,我們可以輕松的重寫(xiě)另一個(gè)實(shí)現(xiàn)來(lái)替換掉,而不是如履薄冰的修改壁涎。

MVP demo

https://github.com/liuguangli/androidmvp

下篇文章將以登錄為業(yè)務(wù)場(chǎng)景分析MVP的具體實(shí)現(xiàn)凡恍。下篇:《Android應(yīng)用架構(gòu)之MVP實(shí)現(xiàn)》

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市怔球,隨后出現(xiàn)的幾起案子嚼酝,更是在濱河造成了極大的恐慌,老刑警劉巖竟坛,帶你破解...
    沈念sama閱讀 216,372評(píng)論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件闽巩,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡担汤,警方通過(guò)查閱死者的電腦和手機(jī)涎跨,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)崭歧,“玉大人隅很,你說(shuō)我怎么就攤上這事÷誓耄” “怎么了叔营?”我有些...
    開(kāi)封第一講書(shū)人閱讀 162,415評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵屋彪,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我绒尊,道長(zhǎng)畜挥,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,157評(píng)論 1 292
  • 正文 為了忘掉前任婴谱,我火速辦了婚禮蟹但,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘勘究。我一直安慰自己矮湘,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,171評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布口糕。 她就那樣靜靜地躺著缅阳,像睡著了一般。 火紅的嫁衣襯著肌膚如雪景描。 梳的紋絲不亂的頭發(fā)上十办,一...
    開(kāi)封第一講書(shū)人閱讀 51,125評(píng)論 1 297
  • 那天,我揣著相機(jī)與錄音超棺,去河邊找鬼向族。 笑死,一個(gè)胖子當(dāng)著我的面吹牛棠绘,可吹牛的內(nèi)容都是我干的件相。 我是一名探鬼主播,決...
    沈念sama閱讀 40,028評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼氧苍,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼夜矗!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起让虐,我...
    開(kāi)封第一講書(shū)人閱讀 38,887評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤紊撕,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后赡突,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體对扶,經(jīng)...
    沈念sama閱讀 45,310評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,533評(píng)論 2 332
  • 正文 我和宋清朗相戀三年惭缰,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了浪南。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,690評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡漱受,死狀恐怖络凿,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤喷众,帶...
    沈念sama閱讀 35,411評(píng)論 5 343
  • 正文 年R本政府宣布,位于F島的核電站紧憾,受9級(jí)特大地震影響到千,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜赴穗,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,004評(píng)論 3 325
  • 文/蒙蒙 一憔四、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧般眉,春花似錦了赵、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,659評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至埠对,卻和暖如春络断,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背项玛。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,812評(píng)論 1 268
  • 我被黑心中介騙來(lái)泰國(guó)打工貌笨, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人襟沮。 一個(gè)月前我還...
    沈念sama閱讀 47,693評(píng)論 2 368
  • 正文 我出身青樓锥惋,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親开伏。 傳聞我的和親對(duì)象是個(gè)殘疾皇子膀跌,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,577評(píng)論 2 353

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