七. Flow 线程操作
7.1 更为简化的线程切换
相对于 RxJava 多线程的学习曲线,Flow 对线程的切换友好地多。
在之前的 Kotlin Coroutines Flow 系列(一) Flow 基本使用 一文中曾经介绍过 Flow 的切换线程,以及 flowOn 操作符。
Flow 只需使用 flowOn 操作符,而不必像 RxJava 需要去深入理解 observeOn、subscribeOn 之间的区别。
7.2 flowOn VS RxJava 的 observeOn
RxJava 的 observeOn 操作符,接收一个 Scheduler 参数,用来指定下游操作运行在特定的线程调度器 Scheduler 上。
Flow 的 flowOn 操作符,接收一个 CoroutineContext 参数,影响的是上游的操作。
例如:
fun main() = runBlocking {
flow {
for (i in 1..5) {
delay(100)
emit(i)
}
}.map {
it * it
}.flowOn(Dispatchers.IO)
.collect {
println("${Thread.currentThread().name}: $it")
}
}
flow builder 和 map 操作符都会受到 flowOn
的影响,并使用 Dispatchers.io 线程池。
再例如:
val customerDispatcher = Executors.newFixedThreadPool(5).asCoroutineDispatcher()
fun m