Rxjava2~zip后续~学渣带你扣rxjava2~ Function到底发挥了什么作用

上一篇 map干了什么
我们来继续上一个话题,我们知道了参数会分别发送自己,然后呢? 他们怎么去合并? 按照zip的最后一个参数中规定的那样。现在让我们来开始今天的话题。


zip(getCricketFansObservable(), getFootballFansObservable(),
new BiFunction, List, List>() {
@Override
public List apply(List cricketFans, List footballFans) throws Exception {
return Utils.filterUserWhoLovesBoth(cricketFans, footballFans);
}
})

在上一篇中我们分析到了 第一个参数会执行这个subscribeActual方法。
当调用observer.onSubscribe(parent);


protected void subscribeActual(Observer observer) {
CreateEmitter parent = new CreateEmitter(observer);
observer.onSubscribe(parent);

    try {
        source.subscribe(parent);
    } catch (Throwable ex) {
        Exceptions.throwIfFatal(ex);
        parent.onError(ex);
    }
}


它就会执行我们我们新建的 e.onNext(Utils.getUserListWhoLovesCricket()); 这两个方法。 e.onComplete();

private Observable> getCricketFansObservable() {
return Observable.create(new ObservableOnSubscribe>() {
@Override
public void subscribe(ObservableEmitter> e) throws Exception {
if (!e.isDisposed()) {
e.onNext(Utils.getUserListWhoLovesCricket());
e.onComplete();
}
}
});
}

一步一步向下进行 你们肯定知道会执行
ObservableCreate下的方法


@Override
public void onNext(T t) {
if (t == null) {
onError(new NullPointerException("onNext called with null. Null values are generally not allowed in 2.x operators and sources."));
return;
}
if (!isDisposed()) {
observer.onNext(t);
}
}

好了 到了这里 没有什么难度。在向下的时候 就要仔细了。 observer.onNext(t); 这个observer是谁的对象?它执行的onnext是谁的方法?你们可以思考一下。

好了 我来揭露谜底 是ObservableZip下的onNext方法。

为什么? 不知道大家还有没有印象


public void subscribe(ObservableSource[] sources, int bufferSize) {
ZipObserver[] s = observers;
int len = s.length;
for (int i = 0; i < len; i++) {
s[i] = new ZipObserver(this, bufferSize);
}
// this makes sure the contents of the observers array is visible
this.lazySet(0);
actual.onSubscribe(this);
for (int i = 0; i < len; i++) {
if (cancelled) {
return;
}
sources[i].subscribe(s[i]);
}
}

sources[i].subscribe(s[i]);这个方法,它的参数s是 ZipObserver[] s,这下明白了吧。

接下来就会执行ZipObserver的


public void onNext(T t) {
queue.offer(t);
parent.drain();
}

马上就要到达最后一步了,drain()方法。这个方法很长。我就不贴了, 只把最重要的贴上来
v = ObjectHelper.requireNonNull(zipper.apply(os.clone())

zipper就是我们Function里面的参数。os就是你们发射的值。在这里执行就是们zip回调的那个接口。对发射的两个数据怎么去操作就是在Function中去设置了。
好了。zipper大家虽然都知道怎么用。 这里我就是想告诉大家这个基本的一个原理。
从这里面可以得到以下几点哦
我这里创建的是两个Observable,


private Observable> getCricketFansObservable() {
return Observable.create(new ObservableOnSubscribe>() {
@Override
public void subscribe(ObservableEmitter> e) throws Exception {
if (!e.isDisposed()) {
e.onNext(Utils.getUserListWhoLovesCricket());
e.onComplete();
}
}
});
}

private Observable> getFootballFansObservable() {
    return Observable.create(new ObservableOnSubscribe>() {
        @Override
        public void subscribe(ObservableEmitter> e) throws Exception {
            if (!e.isDisposed()) {
                e.onNext(Utils.getUserListWhoLovesFootball());
                e.onComplete();
            }
        }
    });
}


在这两个对象中我们都可以对数据进行操作。并且最后合并的时候 是以最少的那个数据为主。相信大家看了之后就会明白。

你可能感兴趣的:(Rxjava2~zip后续~学渣带你扣rxjava2~ Function到底发挥了什么作用)