Android跟我一起來開發(fā)--微影之架構篇

上一篇《Android跟我一起來開發(fā)--微影之開篇》中主要講述了一下寫這些博文的初衷筒扒,以及對項目中數(shù)據(jù)忘苛、架構护奈、框架(依賴)泡嘴、目錄結構作了一些簡單的介紹。接下來本文主要針對MVP架構的個人理解做一個詳細的描述逆济。當然還是站在巨人的肩膀上酌予,我是先通讀了一下各位大神對官方mvp(基礎版)的分析,然后通過實際動手編寫來加深印象幫助自己更好理解奖慌。再次感謝各位大神的無私奉獻(ヽ(≧Д≦)ノ)抛虫。

說到mvp,我們不禁要思考這樣一個人生哲理:我是誰简僧,我來自哪里建椰,我要干什么?讓我們像剝洋蔥一層層剝開你外衣岛马。mvp實際上就是mvc的一個變種棉姐,或者說是進化。在mvc中activity/fragment/view都是屬于view這一層啦逆,負責界面的繪制伞矩、與用戶交互,而實際上它既承擔了View的功能夏志,同時也包含一些Controller的東西乃坤。不僅使代碼看起來臃腫,而且對于開發(fā)與維護來說都不太友好沟蔑。通過把activity/fragment/view中的View和Controller剝離開來形成Presenter湿诊,專職做一些數(shù)據(jù)的處理、邏輯的控制等瘦材。在MVP中厅须,M和V并沒有交集,兩人各自為政食棕,互不干擾朗和,通過P這個老好人作為中間人把三者聯(lián)系起來错沽。通過以下兩張圖可以更清晰的理解mvc和mvp兩者之間的區(qū)別。(圖片來源)

mvc

mvp

為什么要使用mvp

  • 分離了視圖邏輯和業(yè)務邏輯例隆,降低了耦合
  • Activity只處理生命周期的任務甥捺,代碼變得更加簡潔
  • 視圖邏輯和業(yè)務邏輯分別抽象到了View和Presenter的接口中去,提高代碼的可閱讀性
  • Presenter和View被抽象成接口镀层,可以有多種具體的實現(xiàn)镰禾,所以方便進行單元測試
  • 把業(yè)務邏輯抽到Presenter中去,避免后臺線程引用著Activity導致Activity的資源無法被系統(tǒng)回收從而引起內存泄露和OOM

具體用法

說到具體的用法就先來po一張目錄結構圖上來唱逢。
目錄結構圖

從結構圖中不難看出吴侦,model中對應mvp的M層,包含本地數(shù)據(jù)和遠程數(shù)據(jù)(Realm數(shù)據(jù)庫和網絡)坞古;

base中主要是基礎類备韧,其中BaseView中最主要的是setPresenter用于view持有presenter的引用。

void setPresenter(T presenter);
base

presenter包中包含了contract和presenter痪枫。其中contract是一個接口類织堂,主要定義了繼承自baseView和basePresenter的接口,在這里聲明的接口可以一目了然奶陈,通過在V和P中進行實現(xiàn)可以使代碼更清晰簡潔易于管理易阳。

public interface DiscoverContract {    
       interface View extends BaseView<Presenter> {        
            boolean isActive();        
            void showContent(VideoRes videoRes);        
            void refreshFaild(String msg);        
            void hidLoading();        
      }    
      interface Presenter extends BasePresenter {        
            void getData();   
      }
}

下邊是Presenter的實現(xiàn)類,可以看到在presenter的構造方法中持有了對view的引用吃粒,同時調用了view的setPresenter方法綁定了自身使view持有了presenter的引用潦俺,這樣V和P形成了雙向引用的關系。

public class DiscoverPresenter extends RxPresenter implements DiscoverContract.Presenter {    
DiscoverContract.View mView;    
final String catalogId = "402834815584e463015584e53843000b";    
......
     public DiscoverPresenter(@NonNull DiscoverContract.View threeView) {        
          mView = Preconditions.checkNotNull(threeView);
          mView.setPresenter(this);   
       }    
    @Override    
    public void getData() {        
        getNextVideos();    
    }    
......
private void getNextVideos(){......}
}

官方mvp(基礎版)中是以Fragment作為View的具體載體徐勃,我沒有這么做事示,我是以重寫LinearLayout的自定義view作為具體的view載體。來看一下view的代碼:

public class DiscoverView extends RootView<DiscoverContract.Presenter> implements DiscoverContract.View {    
@BindView(R.id.title_name)    ColorTextView titleName;   
......
 public DiscoverView(Context context) {        super(context);    }    
 public DiscoverView(Context context, AttributeSet attrs) {        super(context, attrs);    }    
 @Override    
 protected void getLayout() {        
    inflate(mContext, R.layout.fragment_discover_view, this);    
}    
 @Override    
 public void setPresenter(DiscoverContract.Presenter presenter) {        mPresenter = com.google.common.base.Preconditions.checkNotNull(presenter);    }    
 @Override    
 public void showError(String msg) {     
   EventUtil.showToast(mContext, msg);   
 }    
 @Override    
 public void showContent(final VideoRes videoRes) {        
......
 }   
}

下面在來看一下activity頁面僻肖,代碼是不是清爽多了肖爵,View只管view,Presenter只管邏輯檐涝。

public class CollectionActivity extends SwipeBackActivity {    
@BindView(R.id.collect_view)    
CollectionView collectView;    
@Override    
protected void onCreate(Bundle savedInstanceState) {      
  super.onCreate(savedInstanceState);        
  setContentView(R.layout.activity_collection);        
  unbinder = ButterKnife.bind(this);        
  mPresenter = new CollectionPresenter(collectView, 0);    
  }
}

至此整個過程就算走完了遏匆。看到這里你可能還是云里霧里谁榜,rootview是什么啊,rxpresenter干嘛的凡纳,各個引用啥時候銷毀啊等等(哇咔咔窃植,憋了這這么久憋出來的把自己都快搞暈了,甩甩臉荐糜,今天就到這了巷怜,下篇再針對以上問題進行補充講解葛超,不對,自我解釋延塑。绣张。。)


qq交流群:138485840
下載地址:微影
源碼地址:Ghost
歡迎大家下載和Star

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末关带,一起剝皮案震驚了整個濱河市侥涵,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌宋雏,老刑警劉巖芜飘,帶你破解...
    沈念sama閱讀 217,084評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異磨总,居然都是意外死亡嗦明,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,623評論 3 392
  • 文/潘曉璐 我一進店門蚪燕,熙熙樓的掌柜王于貴愁眉苦臉地迎上來娶牌,“玉大人,你說我怎么就攤上這事馆纳∈迹” “怎么了?”我有些...
    開封第一講書人閱讀 163,450評論 0 353
  • 文/不壞的土叔 我叫張陵厕诡,是天一觀的道長累榜。 經常有香客問我,道長灵嫌,這世上最難降的妖魔是什么壹罚? 我笑而不...
    開封第一講書人閱讀 58,322評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮寿羞,結果婚禮上猖凛,老公的妹妹穿的比我還像新娘。我一直安慰自己绪穆,他們只是感情好辨泳,可當我...
    茶點故事閱讀 67,370評論 6 390
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著玖院,像睡著了一般菠红。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上难菌,一...
    開封第一講書人閱讀 51,274評論 1 300
  • 那天试溯,我揣著相機與錄音,去河邊找鬼郊酒。 笑死遇绞,一個胖子當著我的面吹牛键袱,可吹牛的內容都是我干的。 我是一名探鬼主播摹闽,決...
    沈念sama閱讀 40,126評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼蹄咖,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了付鹿?” 一聲冷哼從身側響起澜汤,我...
    開封第一講書人閱讀 38,980評論 0 275
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎倘屹,沒想到半個月后银亲,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經...
    沈念sama閱讀 45,414評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡纽匙,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,599評論 3 334
  • 正文 我和宋清朗相戀三年务蝠,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片烛缔。...
    茶點故事閱讀 39,773評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡馏段,死狀恐怖,靈堂內的尸體忽然破棺而出践瓷,到底是詐尸還是另有隱情院喜,我是刑警寧澤,帶...
    沈念sama閱讀 35,470評論 5 344
  • 正文 年R本政府宣布晕翠,位于F島的核電站喷舀,受9級特大地震影響,放射性物質發(fā)生泄漏淋肾。R本人自食惡果不足惜硫麻,卻給世界環(huán)境...
    茶點故事閱讀 41,080評論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望樊卓。 院中可真熱鬧拿愧,春花似錦、人聲如沸碌尔。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,713評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽唾戚。三九已至柳洋,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間叹坦,已是汗流浹背膳灶。 一陣腳步聲響...
    開封第一講書人閱讀 32,852評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留立由,地道東北人轧钓。 一個月前我還...
    沈念sama閱讀 47,865評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像锐膜,于是被迫代替她去往敵國和親毕箍。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,689評論 2 354

推薦閱讀更多精彩內容