成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

RxJava中操作符到底做了什么?

開發 后端
RxJava今年徹底火了一把,其中最牛逼之處就是操作符了,以前只知道怎么用,這幾天看了看源碼,大致的弄清楚了操作符的工作過程,今天分享給大家。如果有什么不對地方,請大家多多指教。

RxJava今年徹底火了一把,其中最牛逼之處就是操作符了,以前只知道怎么用,這幾天看了看源碼,大致的弄清楚了操作符的工作過程,今天分享給大家。如果有什么不對地方,請大家多多指教。

今天我們已filter為例,看代碼:

  1. Integer[] datas={1,2,3,4,5,6,7,8,9,10}; 
  2. Observable.from(datas) 
  3.         .filter(new Func1<Integer, Boolean>() { 
  4.             @Override 
  5.             public Boolean call(Integer integer) { 
  6.                 return integer>=5; 
  7.             } 
  8.         }) 
  9.         .subscribe(new Action1<Integer>() { 
  10.             @Override 
  11.             public void call(Integer integer) { 
  12.                 mText.append(integer.toString()+","); 
  13.             } 
  14.         }); 

一個很簡單的小例子,用過濾操作符 filter 找出大于等于5的數字。我們點進去看看源碼中filter做了什么

  1. public final Observable<T> filter(Func1<? super T, Boolean> predicate) {  
  2. return create(new OnSubscribeFilter<T>(this, predicate));  

調用了create()方法,等等我們什么時候是不是也用過create() 方法,我們在創建Observable時候也用過create()方法,原來創建了一個新的Observable返回出去了,那豈不是說我們的訂閱者其實訂閱的是這個新的Observable,我們繼續往下看create方法,create方法需要的參數是一個OnSubscribe對象,那我們可以確定OnSubscribeFilter是OnSubscribe的一個實現類,我們點進去看看。

  1. public final class OnSubscribeFilter<T> implements OnSubscribe<T> { 
  2.     
  3.        final Observable<T> source; 
  4.     
  5.        final Func1<? super T, Boolean> predicate; 
  6.     
  7.        public OnSubscribeFilter(Observable<T> source, Func1<? super T, Boolean> predicate) { 
  8.            this.source = source; 
  9.            this.predicate = predicate; 
  10.        } 

果然不出我們所料,OnSubscribeFilter是OnSubscribe的實現類,我們看他的構造方法,傳遞了兩個參數,第一個參數Observable對象,一個Func1,其中第一個參數就是我們我們自己創建的那個Observable,第二個參數使我們在外面寫的Func1,然后保存了起來。我們都知道在subscribe()訂閱的時候,OnSubscribe的call()方法。我們看看OnSubscribeFilter的call()方法都干了些什么

  1. @Override 
  2.         public void call(final Subscriber<? super T> child) { 
  3.             FilterSubscriber<T> parent = new FilterSubscriber<T>(child, predicate); 
  4.             child.add(parent); 
  5.             source.unsafeSubscribe(parent); 
  6.         } 

出現了一個FilterSubscriber,什么鬼玩意兒,我們看看他是什么鬼

  1.  
  2.       @Override 
  3.       public void onError(Throwable e) { 
  4.           if (done) { 
  5.               RxJavaHooks.onError(e); 
  6.               return
  7.           } 
  8.           done = true
  9.  
  10.           actual.onError(e); 
  11.       } 
  12.  
  13.  
  14.       @Override 
  15.       public void onCompleted() { 
  16.           if (done) { 
  17.               return
  18.           } 
  19.           actual.onCompleted(); 
  20.       } 
  21.       @Override 
  22.       public void setProducer(Producer p) { 
  23.           super.setProducer(p); 
  24.           actual.setProducer(p); 
  25.       } 
  26.   } 

一個Subscriber的子類,我們看他的構造方法,兩個參數,一個Subscriber一個Func1,我們在創建對象時候Subscriber對象是我們真正的從外界傳過來的觀察者,Func1呢使我們創建OnSubscribeFilter時候傳遞進來的對象,也就是我們在外界定義的Func1。

回過頭來我們繼續看OnSubscribeFilter的call方法。我們看到source.unsafeSubscribe(parent),source是我們原來外界的Observable,他訂閱了FilterSubscriber對象。我們在他的onNext方法中看到他根據func1.call(t)的返回值來判斷是否讓我們外界的真正的觀察者調用onNext方法。

看到這里有沒有恍然大悟,啥?我都不知道你在說啥,額,那我們整體的屢屢。

我們外界的代碼,在subscribe()時候,Subscriber并不是訂閱了我們自己寫的Observable,Subscriber訂閱的是filter方法返回的那個新的Observable對象,所以訂閱時候會調用OnSubscribeFilter的call方法,OnSubscribeFilter才是我們訂閱的被觀察者的onSubscribe對象,在OnSubscribeFilter的call()方法中,我們讓我們包裝的FilterSubscriber訂閱我們原來的被觀察者,也就是我們在外界生成的那個Observable。我們在外界的Observable的onSubscribe對象的call方法中得到的觀察者是FilterSubscriber對象,我們調用的onNext會回調到FilterSubscriber的onNext方法中。在FilterSubscriber的onNext方法中我們根據我們傳遞的Func1來判斷是否要回調真正的Subscriber的onNext方法,在為true的時候我們才回調我們外界的觀察者的onNext方法,也就起到了過濾的作用。這就是Filter的整個的流程。

我們來測試下我們的小結論:

  1. Observable.create(new Observable.OnSubscribe<Integer>() { 
  2.                @Override 
  3.                public void call(Subscriber<? super Integer> subscriber) { 
  4.                    Log.e("call:subscriber""" + subscriber.getClass().getCanonicalName()); 
  5.                    subscriber.onNext(5); 
  6.                } 
  7.            }).filter(new Func1<Integer, Boolean>() { 
  8.                @Override 
  9.                public Boolean call(Integer integer) { 
  10.                    return integer > 0; 
  11.                } 
  12.            }).subscribe(new Action1<Integer>() { 
  13.                @Override 
  14.                public void call(Integer integer) { 
  15.                     
  16.                } 
  17.            }); 
責任編輯:武曉燕 來源: segmentfault
相關推薦

2016-12-28 09:54:50

AndroidRxJava操作符

2017-01-03 16:12:13

RxJava操作符Android

2017-01-03 15:56:20

RxJava操作符Android

2016-12-28 09:48:09

AndroidRxJava操作符

2010-07-14 14:55:07

Perl操作符

2021-10-31 18:59:55

Python操作符用法

2009-08-19 17:26:28

C# 操作符

2021-10-09 13:48:11

操作符Python運算符

2011-04-08 16:26:14

JavaScript

2010-07-19 11:00:24

Perl操作符

2010-07-14 14:30:31

Perl操作符

2009-09-15 17:16:58

LINQ查詢操作符

2012-02-06 09:13:23

LINQ

2009-09-16 09:09:23

Linq Contai

2010-07-14 14:18:51

Perl操作符

2009-07-21 09:31:00

Scala操作符

2010-01-28 11:16:28

C++操作符

2011-04-19 10:04:25

NeopPIshell網站后門

2011-11-29 09:10:11

Hadoop

2020-12-26 16:51:12

Python操作符開發
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲国产成人在线观看 | 在线视频一区二区三区 | 欧美精品成人 | 日韩亚洲一区二区 | 国产一区二区三区久久久久久久久 | 亚洲午夜av久久乱码 | 国产精品二区三区 | 成人日批视频 | 日韩靠逼 | 久久91精品久久久久久9鸭 | 国产视频久久久 | 91精品国产综合久久婷婷香蕉 | 国产精品中文字幕在线 | 国产精品第2页 | 日本综合在线观看 | 欧美成人激情视频 | 黄网站免费观看 | 久久成人国产 | 欧美啪啪网站 | 米奇成人网 | 日韩一区在线观看视频 | 国产精品日韩欧美一区二区 | 黄色男女网站 | 亚洲国产一区二区三区四区 | 亚洲欧美精品久久 | 国产精品大片 | 久久成人精品一区二区三区 | 在线视频日韩精品 | 色婷婷综合久久久久中文一区二区 | 亚洲国产成人久久久 | 国产成人小视频 | 成人av大全| 欧美区日韩区 | 成人性视频在线播放 | 精品福利视频一区二区三区 | 久久久久国产 | www.xxxx欧美| 欧美在线a | 欧美一区2区三区4区公司二百 | 精品美女久久久 | 久久久女女女女999久久 |