在下面的代码行中
@Test
fun rx() {
val items = Observable.just(1, 2, 3, 4, 5)
.observeOn(Schedulers.io()) //<---- if remove this line each item is emitted by sequentially (i.e 12345)
items
.filter { it == 1 }
.doOnNext { print("1") }
.subscribe()
items
.filter { it == 2 }
.doOnNext { print("2") }
.subscribe()
items
.filter { it == 3 }
.doOnNext { print("3") }
.subscribe()
items
.filter { it == 4 }
.doOnNext { print("4") }
.subscribe()
items
.filter { it == 5 }
.doOnNext { print("5") }
.subscribe()
Thread.sleep(1000)
}
我希望日志应该说“12345”,但它说的是 23415、31245、53124 等。(即订单看起来像随机的)
每个项目 1、2、3、4、5 似乎不是按顺序发出的。
有什么理由吗?以及如何使用 ".observeOn(Schedulers.io())" 修复它?