RxJava2配置及使用

RxJava2.0是一個非常棒的流式編程,采用的觀察者模式思想,事件的產(chǎn)生者產(chǎn)生事間之后發(fā)送給綁定的接受者,接受順序與發(fā)送順序一致.

<br />
依賴:

  compile 'io.reactivex.rxjava2:rxjava:2.0.1'
  compile 'io.reactivex.rxjava2:rxandroid:2.0.1'

<br />
簡單使用:

//觀察者模式,這里產(chǎn)生事件,事件產(chǎn)生后發(fā)送給接受者,但是一定要記得將事件的產(chǎn)生者和接收者捆綁在一起,否則會出現(xiàn)錯誤
Observable.create(new ObservableOnSubscribe<String>() {
  @Override
  public void subscribe(ObservableEmitter<String> e) throws Exception {
      //這里調(diào)用的方法會在產(chǎn)生事件之后會發(fā)送給接收者,接收者對應(yīng)方法會收到
      e.onNext("hahaha");
      e.onError(new Exception("wulala"));
      e.onComplete();
  }/*--
}).subscribe(new Observer<String>() {
  //接受者,根據(jù)事件產(chǎn)生者產(chǎn)生的事件調(diào)用不同方法
  @Override
  public void onSubscribe(Disposable d) {
      Log.e(TAG, "onSubscribe: ");
  }

  @Override
  public void onNext(String value) {
      Log.e(TAG, "onNext: " + value);
  }

  @Override
  public void onError(Throwable e) {
      Log.e(TAG, "onError: ", e);
  }

  @Override
  public void onComplete() {
      Log.e(TAG, "onComplete: ");
  }
});

我們來用圖解一下這其中發(fā)生了什么事:

Paste_Image.png

上游朝下游發(fā)送數(shù)據(jù),經(jīng)過subscribe使上下游產(chǎn)生關(guān)系,即達(dá)成訂閱.

<br />

解析1:
ObservableEmitter,這是個啥東西?Emitter:顧名思義,即Rxjava的發(fā)射器,通過這個發(fā)射器,即可發(fā)送事件-----通過調(diào)用onNext,onError,onComplete方法發(fā)送不同事件.

注意:
雖然RxJava可以進(jìn)行事件發(fā)送,但這并不意味著你可以隨便發(fā)送,這其中需要遵循一些規(guī)則.
<br />
onNext:你可以發(fā)送無數(shù)個onNext,發(fā)送的每個onNext接受者都會接收到.
<br />
onError:當(dāng)發(fā)送了onError事件之后,發(fā)送者onError之后的事件依舊會繼續(xù)發(fā)送,但是接收者當(dāng)接收到onError之后就會停止接收事件了.
<br />
onComplete:當(dāng)發(fā)送了onComplete事件之后,發(fā)送者的onComplete之后的事件依舊會繼續(xù)發(fā)送,但是接收者接收到onComplete之后就停止接收事件了.
<br />
onError事件和onComplete事件是互斥的,但是這并不代表你配置了多個onError和onComplete一定會崩潰,多個onComplete是可以正常運(yùn)行的,但是只會接收到第一個,之后的就不會再接收到了,多個onError時,只會接收到第一個,第二個會直接造成程序崩潰.

<br />
解析2:
Disposable又是個啥東西,翻譯之后百度告訴我這東西叫做一次性的,是用來控制發(fā)送者和接受者之間的紐帶的,默認(rèn)為false,表示發(fā)送者和接受者直接的通信閥門關(guān)閉,可以正常通信,在調(diào)用dispose()方法之后,閥門開啟,會阻斷發(fā)送者和接收者之間的通信,從而斷開連接.

重載方法:

          subscribe();          //表示發(fā)送者隨意發(fā)送數(shù)據(jù),接受者什么都不管,什么都不接收.
          subscribe(Consumer<? super T> onNext) {}     //只響應(yīng)onNext()事件,其他的事件忽略.
          subscribe(Consumer<? super T> onNext, Consumer<? super Throwable> onError) {}         //含義同上
          subscribe(Consumer<? super T> onNext, Consumer<? super Throwable> onError, Action onComplete) {}         //含義同上
          subscribe(Consumer<? super T> onNext, Consumer<? super Throwable> onError, Action onComplete, Consumer<? super Disposable> onSubscribe) {}     //含義同上

<br />
解析3:
默認(rèn)情況下,發(fā)送者和接收者都運(yùn)行在主線程,但是這顯然是不符合實際需求的,我們在日常使用中,通常用的最多的就是在子線程進(jìn)行各種耗時操作,然后發(fā)送到主線程進(jìn)行,難道我們就沒有辦法繼續(xù)用這個優(yōu)秀的庫了?想多了你,一個優(yōu)秀的庫如果連這都想不到,怎么能被稱為優(yōu)秀呢,RxJava中有線程調(diào)度器,通過線程調(diào)度器,我們可以很簡單的實現(xiàn)這種效果,下面放代碼.

Observable.create(new ObservableOnSubscribe<String>() {
    @Override
    public void subscribe(ObservableEmitter<String> e) throws Exception {
        e.onNext("hahaha");
        e.onNext("hahaha");
        e.onNext("hahaha");
        Log.e(TAG,"運(yùn)行在什么線程" + Thread.currentThread().getName());
        e.onComplete();
    }
}).subscribeOn(Schedulers.newThread())               //線程調(diào)度器,將發(fā)送者運(yùn)行在子線程
  .observeOn(AndroidSchedulers.mainThread())          //接受者運(yùn)行在主線程
  .subscribe(new Observer<String>() {
    @Override
    public void onSubscribe(Disposable d) {
        Log.e(TAG, "onSubscribe: ");
        Log.e(TAG,"接收在什么線程" + Thread.currentThread().getName());
    }

    @Override
    public void onNext(String value) {
        Log.e(TAG, "onNext: " + value);
    }

    @Override
    public void onError(Throwable e) {
        Log.e(TAG, "onError: ", e);
    }

    @Override
    public void onComplete() {
        Log.e(TAG, "onComplete: ");
    }
});

最終結(jié)果:

Paste_Image.png

可以看到我們只加了兩行代碼,就實現(xiàn)了效果,還有比這個更優(yōu)秀,更簡單的么?

注意事項:
subscribeOn(),只有在第一次調(diào)用的時候生效,之后不管調(diào)用多少次,只會以第一次為準(zhǔn).
observeOn(),可以被調(diào)用多次,每次調(diào)用都會更改線程.

RxJava線程池中的幾個線程選項
- Schedulers.io() io操作的線程, 通常io操作,如文件讀寫.
- Schedulers.computation() 計算線程,適合高計算,數(shù)據(jù)量高的操作.
- Schedulers.newThread() 創(chuàng)建一個新線程,適合子線程操作.
- AndroidSchedulers.mainThread() Android的主線程,主線程

本文介紹簡單使用,下一篇開始講解RxJava中的操作符.

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末丁逝,一起剝皮案震驚了整個濱河市挖函,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌琅关,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,651評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡超升,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,468評論 3 392
  • 文/潘曉璐 我一進(jìn)店門哺徊,熙熙樓的掌柜王于貴愁眉苦臉地迎上來室琢,“玉大人,你說我怎么就攤上這事落追∮危” “怎么了?”我有些...
    開封第一講書人閱讀 162,931評論 0 353
  • 文/不壞的土叔 我叫張陵轿钠,是天一觀的道長巢钓。 經(jīng)常有香客問我,道長疗垛,這世上最難降的妖魔是什么症汹? 我笑而不...
    開封第一講書人閱讀 58,218評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮贷腕,結(jié)果婚禮上背镇,老公的妹妹穿的比我還像新娘。我一直安慰自己泽裳,他們只是感情好瞒斩,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,234評論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著涮总,像睡著了一般胸囱。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上瀑梗,一...
    開封第一講書人閱讀 51,198評論 1 299
  • 那天烹笔,我揣著相機(jī)與錄音裳扯,去河邊找鬼。 笑死谤职,一個胖子當(dāng)著我的面吹牛嚎朽,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播柬帕,決...
    沈念sama閱讀 40,084評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼狡门!你這毒婦竟也來了陷寝?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,926評論 0 274
  • 序言:老撾萬榮一對情侶失蹤其馏,失蹤者是張志新(化名)和其女友劉穎凤跑,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體叛复,經(jīng)...
    沈念sama閱讀 45,341評論 1 311
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡仔引,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,563評論 2 333
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了褐奥。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片咖耘。...
    茶點(diǎn)故事閱讀 39,731評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖撬码,靈堂內(nèi)的尸體忽然破棺而出儿倒,到底是詐尸還是另有隱情,我是刑警寧澤呜笑,帶...
    沈念sama閱讀 35,430評論 5 343
  • 正文 年R本政府宣布夫否,位于F島的核電站,受9級特大地震影響叫胁,放射性物質(zhì)發(fā)生泄漏凰慈。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,036評論 3 326
  • 文/蒙蒙 一驼鹅、第九天 我趴在偏房一處隱蔽的房頂上張望微谓。 院中可真熱鬧,春花似錦谤民、人聲如沸堰酿。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,676評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽触创。三九已至,卻和暖如春为牍,著一層夾襖步出監(jiān)牢的瞬間哼绑,已是汗流浹背岩馍。 一陣腳步聲響...
    開封第一講書人閱讀 32,829評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留抖韩,地道東北人蛀恩。 一個月前我還...
    沈念sama閱讀 47,743評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像茂浮,于是被迫代替她去往敵國和親双谆。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,629評論 2 354

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