Android應(yīng)用架構(gòu)思想分析
算算日子,工作剛好三年了。這篇開始,鄙人就要向著各種以前想起來就頭大的方向努力前進(jìn)了。作為在Android應(yīng)用層搬磚多年的民工,首篇我想談?wù)勛约簩?duì)架構(gòu)思想的一些看法。如有不妥,還請(qǐng)拍磚。
蓋樓的故事(虛構(gòu))
有一塊地,兩個(gè)區(qū)域,開發(fā)商分別讓兩個(gè)包工頭負(fù)責(zé)開發(fā)。
包工頭A辦事干凈利落,甩開膀子就開工了。為了省錢雇了一個(gè)全能的工人,他既要去采購蓋房的材料,又要用這些材料蓋房子。起初底層屋子結(jié)構(gòu)簡(jiǎn)單,還能應(yīng)付得來,到了后面復(fù)雜的設(shè)計(jì)需求時(shí),忙的不可開交,經(jīng)常精疲力盡,阻斷了蓋房子的進(jìn)程,使得老板很是不開心,偶爾讓他改個(gè)屋子結(jié)構(gòu),他要把整層樓都推到才能實(shí)現(xiàn),嚴(yán)重影響了工期。畫的圖紙都是一次性的,不能重用,耗時(shí)又耗錢,開發(fā)商整天吹胡子瞪眼的跟在屁股后面催。
包工頭B拿到開發(fā)商方案后,先召集小弟開了個(gè)會(huì),確定了所有樓層的樣式,并把它們拆分成獨(dú)立的模塊。按照模塊劃分給了各個(gè)負(fù)責(zé)人,有制定樓層樣式的,有專門負(fù)責(zé)資源提供的,有負(fù)責(zé)運(yùn)送資源的,有按照預(yù)定方案實(shí)施的等等?;舜蟀雮€(gè)月將所有任務(wù)都分配完畢,開始施工。雖然人雇傭的有點(diǎn)多,前面的時(shí)間也耽誤了大半個(gè)月,但是一開工很快就趕上了隔壁樓。emmm,開發(fā)商喜笑顏開,點(diǎn)點(diǎn)頭,這個(gè)錢花的劃算,完事后以后就用包工頭B了。
不久后,兩塊地都完工了。這時(shí)質(zhì)檢開始了,令人頭疼的A區(qū)域,有個(gè)小毛病就要拆掉一大片地方去改造,有的地方改好了卻又影響了其它地方,而反觀B區(qū)域,專人負(fù)責(zé)只要改有問題的地方就好了。
后來,包工頭A游走在各個(gè)小開發(fā)商,工資又低又累,而包工頭B已經(jīng)走上了人生巔峰。(哈哈,終結(jié))
包工頭B的巔峰秘籍
我們?cè)賮砘仡櫼幌掳ゎ^B的蓋樓經(jīng)過。
接到項(xiàng)目,沒有立即開發(fā),開會(huì)整理需求;
按需求、職能劃分模塊,并由對(duì)應(yīng)的人員負(fù)責(zé);
各功能模塊的負(fù)責(zé)人扁平化管理,沒有相互掣肘;
同樣的,我們App的開發(fā)也是一樣的道理,不能像包工頭A一樣把所有的任務(wù)都交給Activity去做。我們要像包工頭B一樣分層去創(chuàng)建App。大家可以了解一下clean Architecture,這里將App應(yīng)用分為三層,內(nèi)-中-外,然后由4個(gè)管理者分別去管理他們。
分層的準(zhǔn)則:
- 由外到內(nèi)抽象
- 內(nèi)層不了解層,外層依賴內(nèi)層
- 分工明確,相互獨(dú)立
先來解釋一下第一條,以往我們開發(fā)App都是先從界面開始,然后最終到業(yè)務(wù)邏輯。現(xiàn)在要反過來,接到需求,要先明確實(shí)體是什么
(舉個(gè)例子,比如登錄功能,它所描述的實(shí)體就是用戶User),然后它有哪些行為(比如登陸,登出userCase)。最后再到具體功能實(shí)現(xiàn)。
內(nèi)層不了解外層,還是拿登錄來說,在內(nèi)層只需要知道用戶有登錄以及登出的行為就可以了,至于它是如何進(jìn)行這些行為,內(nèi)層就不需要知道了,但是反過來外層要實(shí)現(xiàn)內(nèi)層的行為就要知道內(nèi)層有哪些行為于是便產(chǎn)生了依賴關(guān)系。內(nèi)層能獨(dú)立存在,而外層必須依賴內(nèi)層。
分工明確,相互獨(dú)立,講的是各模塊功能獨(dú)立存在,就比如登錄,和注冊(cè)功能是相互獨(dú)立的,各司其職,不能越俎代庖。
4個(gè)管理者
- domain:定義抽象實(shí)體,核心業(yè)務(wù)邏輯,以及數(shù)據(jù)輸出接口。此層為純java代碼,建議直接創(chuàng)建java module。
- data:數(shù)據(jù)管理,分為本地的存儲(chǔ)(sqlLite,sharedpreferences),以及服務(wù)端Api。
- device:與Android底層相關(guān),如通知,藍(lán)牙,傳感器等等。
- app:我們最熟悉的層級(jí),內(nèi)部可以根據(jù)各自的喜好選擇MVP,以及MVVM模式來實(shí)現(xiàn)UI界面。
App開發(fā)的流程
- domain層中定義抽象實(shí)體,設(shè)定其對(duì)應(yīng)的行為。
- data層中,給予數(shù)據(jù)支持
- device層,按需開發(fā)
app層,這里以MVP為例,首先在presenter中實(shí)現(xiàn)domain層定義的所有行為,data層和device層協(xié)助。最后實(shí)現(xiàn)UI界面,完成功能。
相關(guān)文章
Android中實(shí)現(xiàn)多行、水平滾動(dòng)的分頁的Gridview實(shí)例源碼
如果單行水平滾動(dòng),可以用Horizontalscrollview實(shí)現(xiàn)。如果是多行水平滾動(dòng),則結(jié)合Gridview(一般是垂直滾動(dòng)的)和Horizontalscrollview實(shí)現(xiàn)2013-06-06Flutter進(jìn)階質(zhì)感設(shè)計(jì)之標(biāo)簽欄
這篇文章主要為大家詳細(xì)介紹了Flutter進(jìn)階質(zhì)感設(shè)計(jì)之標(biāo)簽欄,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-08-08android相冊(cè)選擇圖片的編碼實(shí)現(xiàn)代碼
本篇文章主要介紹了android相冊(cè)選擇圖片的編碼實(shí)現(xiàn)代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-08-08Android通過ExifInterface判斷Camera圖片方向的方法
今天小編就為大家分享一篇關(guān)于Android通過ExifInterface判斷相機(jī)圖片朝向的方法,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2018-12-12Android如何跳轉(zhuǎn)到應(yīng)用商店的APP詳情頁面
最近做項(xiàng)目遇到這樣的需求,要求從App內(nèi)部點(diǎn)擊按鈕或鏈接,跳轉(zhuǎn)到應(yīng)用商店的某個(gè)APP的詳情頁面,怎么實(shí)現(xiàn)此功能呢?下面小編給大家分享Android如何跳轉(zhuǎn)到應(yīng)用商店的APP詳情頁面,需要的朋友參考下2017-01-01Android開發(fā)中ListView自定義adapter的封裝
這篇文章主要為大家詳細(xì)介紹了android開發(fā)中ListView自定義adapter的封裝,ListView的模板寫法,感興趣的小伙伴們可以參考一下2016-09-09Adapter模式實(shí)戰(zhàn)之重構(gòu)鴻洋集團(tuán)的Android圓形菜單建行
這篇文章主要介紹了Adapter模式實(shí)戰(zhàn)之重構(gòu)鴻洋集團(tuán)的Android圓形菜單建行的相關(guān)資料,需要的朋友可以參考下2016-03-03Android編程實(shí)現(xiàn)滑動(dòng)開關(guān)組件功能【附源碼下載】
這篇文章主要介紹了Android編程實(shí)現(xiàn)滑動(dòng)開關(guān)組件功能,結(jié)合實(shí)例形式詳細(xì)分析了Android滑動(dòng)開關(guān)組件的簡(jiǎn)單布局與功能實(shí)現(xiàn)技巧,并附帶完整實(shí)例源碼供讀者下載參考,需要的朋友可以參考下2018-01-01