七. 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).asCoroutineDispatche

本文详细探讨了Kotlin Coroutines Flow在处理线程操作方面的优势,对比了flowOn与RxJava的observeOn,展示了如何使用buffer进行并发操作,并讨论了并行执行的实现方式,强调Flow在并发控制上的简洁性。
最低0.47元/天 解锁文章
2379

被折叠的 条评论
为什么被折叠?



