本文只是通过例子,把concat操作符中自定义Observable中onNext,onError,onComplte在subscribe后的执行顺序打印出来给大家看看.(concat操作符的作用是连接操作符,可接受Observable的可变参数,或者Observable的集合然后顺序的发送出去,注意是有序的发送,那么这个就可以应用在开发中很多有序的事件,比如接广告…)
废话不多说,我们先看下没有执行之前的代码
observable1
Observable<Integer> observable1 = Observable.create(new ObservableOnSubscribe<Integer>() {
@Override
public void subscribe(@NonNull ObservableEmitter<Integer> e) throws Exception {
e.onNext(1);
LogUtil.d("Emitter : 1");
e.onNext(2);
LogUtil.d("Emitter : 2");
e.onComplete();
LogUtil.d("onComplete1");
}
});
observable2
Observable<Integer> observable2 = Observable.create(new ObservableOnSubscribe<Integer>() {
@Override
public void subscribe(@NonNull ObservableEmitter<Integer> e) throws Exception {
e.onNext(3);
LogUtil.d("Emitter : 3");
e.onNext(4);
LogUtil.d("Emitter : 4");
e.onComplete();
LogUtil.d("onComplete2");
}
});
subscribe
Observable.concat(observable1, observable2)
.subscribe(new Consumer<Integer>() {
@Override
public void accept(@NonNull Integer integer) throws Exception {
LogUtil.d("onNext : " + integer + "\n");
}
}, new Consumer<Throwable>() {
@Override
public void accept(@NonNull Throwable throwable) throws Exception {
LogUtil.d("Throwable");
}
}, new Action() {
@Override
public void run() throws Exception {
LogUtil.d("onComplete");
}
});
OK,那么我们首先运行一下,看下是什么结果…
D/leo: onNext : 1
D/leo: Emitter : 1
D/leo: onNext : 2
D/leo: Emitter : 2
D/leo: onComplete1
D/leo: onNext : 3
D/leo: Emitter : 3
D/leo: onNext : 4
D/leo: Emitter : 4
D/leo: onComplete2
D/leo: onComplete
一切都很正常,如果我们把1中的onComplete取消掉呢?
Observable<Integer> observable1 = Observable.create(new ObservableOnSubscribe<Integer>() {
@Override
public void subscribe(@NonNull ObservableEmitter<Integer> e) throws Exception {
e.onNext(1);
LogUtil.d("Emitter : 1");
e.onNext(2);
LogUtil.d("Emitter : 2");
//e.onComplete();
// LogUtil.d("onComplete1");
}
});
结果是
D/leo: onNext : 1
D/leo: Emitter : 1
D/leo: onNext : 2
D/leo: Emitter : 2
结论:如果自定义Observable使用在Concat中,如果要想执行下一个Observable那么前一个Obeservable必须要执行onComplete方法
如果1中的onComplete放开,2中onComplete注释掉的话:
Observable<Integer> observable2 = Observable.create(new ObservableOnSubscribe<Integer>() {
@Override
public void subscribe(@NonNull ObservableEmitter<Integer> e) throws Exception {
e.onNext(3);
LogUtil.d("Emitter : 3");
e.onNext(4);
LogUtil.d("Emitter : 4");
// e.onComplete();
//LogUtil.d("onComplete2");
}
});
结果是:
D/leo: onNext : 1
D/leo: Emitter : 1
D/leo: onNext : 2
D/leo: Emitter : 2
D/leo: onComplete1
D/leo: onNext : 3
D/leo: Emitter : 3
D/leo: onNext : 4
D/leo: Emitter : 4
结论:concat中所有的Observable都要走完onComplete方法,不然 subscribe中的onComplete将不会执行
如果将1中的onComplete放在onNext(2)之前:
Observable<Integer> observable1 = Observable.create(new ObservableOnSubscribe<Integer>() {
@Override
public void subscribe(@NonNull ObservableEmitter<Integer> e) throws Exception {
e.onNext(1);
LogUtil.d("Emitter : 1");
e.onComplete();
LogUtil.d("onComplete1");
e.onNext(2);
LogUtil.d("Emitter : 2");
}
});
结果是:
D/leo: onNext : 1
D/leo: Emitter : 1
D/leo: onComplete1
D/leo: Emitter : 2
D/leo: onNext : 3
D/leo: Emitter : 3
D/leo: onNext : 4
D/leo: Emitter : 4
D/leo: onComplete2
D/leo: onComplete
结论:自定义observable中 onComplete方法后的onNext会发送 但是subscribe并不会接受到.
我们把1,2中的onComplete之前加onError方法呢:
1. e.onNext(1);
LogUtil.d("Emitter : 1");
e.onNext(2);
LogUtil.d("Emitter : 2");
e.onError(new AndroidException("error"));
LogUtil.d("error1");
e.onComplete();
LogUtil.d("onComplete1");
2. e.onNext(3);
LogUtil.d("Emitter : 3");
e.onNext(4);
LogUtil.d("Emitter : 4");
e.onError(new AndroidException("error"));
LogUtil.d("error2");
e.onComplete();
LogUtil.d("onComplete2");
结果是:
D/leo: onNext : 1
D/leo: Emitter : 1
D/leo: onNext : 2
D/leo: Emitter : 2
D/leo: error1
D/leo: onComplete1
D/leo: Throwable
结论:onError方法走后,后面的方法会发送 但是不会被subscribe接受 而后面的Observable将不会被执行
那如果把1中的onComplete放在onError之前呢 会发生什么:
e.onNext(1);
LogUtil.d("Emitter : 1");
e.onNext(2);
LogUtil.d("Emitter : 2");
e.onComplete();
LogUtil.d("onComplete1");
e.onError(new AndroidException("error"));
LogUtil.d("error1");
首选结果是:
D/leo: onNext : 1
D/leo: Emitter : 1
D/leo: onNext : 2
D/leo: Emitter : 2
D/leo: onComplete1
但是同时APP直接崩溃了,并且报了一个错误
io.reactivex.exceptions.UndeliverableException: android.util.AndroidException: error
这个错误在同时有两个onError也会报(这样的情况我之前遇到过,在接广告的时候 我在广告SDK返回adFailed方法中调用了onError),这个错误我暂时的理解是 onComplete执行后 自身的Observable不再有发送onError的能力 同时 OnError执行后不再有发送OnError的能力 就会报这个错误 如果有遇到这个错误 那么请检查自己Observable里面有没有这样的顺序.