我遇到的问题是,当我使用flatmap时,我的Observable链不会终止。
我已经将我的例子归结为:
int count = Observable.just(1,2,3)
.flatMap(s -> Observable.<Integer>create(subscr-> {
subscr.onNext(s);
if(s>2) {
subscr.onCompleted();
}
}))
.doOnEach(a->System.err.println(a.getKind()+" -> "+a.toString()))
.count()
.toBlocking()
.first();
System.err.println("Count: "+count);
我希望'doOnEach'报告三个onNext事件,然后是onCompleted,最后链应该终止。
然而,输出是这样的:
OnNext -> [rx.Notification@c9e6d24d OnNext 1]
OnNext -> [rx.Notification@c9e6d24e OnNext 2]
OnNext -> [rx.Notification@c9e6d24f OnNext 3]
(然后继续悬挂)
如果我删除flatMap运算符:
int count = Observable.just(1,2,3)
.doOnEach(a->System.err.println(a.getKind()+" -> "+a.toString()))
.count()
.toBlocking()
.first();
System.err.println("Count: "+count);
......它完全符合预期:
CREATED!
OnNext -> [rx.Notification@e3598bd9 OnNext 1]
OnNext -> [rx.Notification@e3598bda OnNext 2]
OnNext -> [rx.Notification@e3598bdb OnNext 3]
OnCompleted -> [rx.Notification@3834d63f OnCompleted]
Count: 3
我想我做错了什么(我无法想象这种基本场景中的错误),但我没有看到它。
感谢任何帮助......(我正在使用RxJava 1.1.0)
答案 0 :(得分:8)
问题在于以下几行:
if(s>2) {
subscr.onCompleted();
}
Observable
和s == 1
的{p> s == 2
不会发出onCompleted
。由于flatMap
仅在完成所有onCompleted
时发出Observable
,因此在您的情况下它不会发出onCompleted
。