您的位置:首页 > 编程语言 > Java开发

Rxjava2中Concat操作符onNext,OnError,OnComplte的执行顺序

2017-07-13 12:01 176 查看

本文只是通过例子,把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里面有没有这样的顺序.

暂时先写到这里,因为马上要吃饭了,12:00 ,写这个的目的只是为了做个记录顺便帮助到要了解这块的同志. 如果有错误的地方还请指出,我将及时修改 如果有没考虑到的地方 也请联系我让我写上去:QQ/WX:15921449923.

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息