我是 RxScala Observables 的新手,在使用 take(n) 和 doOnCompleted() 的组合时遇到了奇怪的行为。
下面我有一个测试示例,我认为第一个订阅是正确的(在开始时使用 take(2))并输出订阅、下一个、完成和取消订阅方法的所有日志,但是第二个测试(take(2 ) 在 doOnComplete) 之后永远不会到达 doOnCompleted 方法。
import rx.lang.scala.Observable
object Tester extends App {
val obs = Observable.from(List(1,2,3,4))
val obsAddMethodsCorrect = obs.take(2)
.doOnSubscribe( println("subscribe") )
.doOnNext( n => println(s"next $n") )
.doOnError( e => println("error") )
.doOnCompleted( println("completed") )
.doOnUnsubscribe( println("unsubscribe") )
val obsAddMethodsInCorrect = obs
.doOnError( e => println("error") )
.doOnCompleted( println("completed") )
.take(2)
.doOnNext( n => println(s"next $n") )
.doOnUnsubscribe( println("unsubscribe") )
.doOnSubscribe( println("subscribe") )
obsAddMethodsCorrect.toBlocking.subscribe()
println("")
println("The above seems correct. Below seems incorrect")
println("")
obsAddMethodsInCorrect.toBlocking.subscribe()
}
上述测试的电流输出如下。
subscribe
next 1
next 2
completed
unsubscribe
The above seems correct. Below seems incorrect
subscribe
next 1
next 2
unsubscribe
为什么 doOnCompleted() 在第二个示例中没有被解雇?