要实现返回多个值,我们可以使用List或者Sequence序列,但是我们有个重要要求就是能实现异步操作并可以逐个返回,显然,使用List或者Sequence序列并不能实现这样的效果(原因不赘述了,主要就是List不能实现逐个返回,Sequence不能实现异步操作),下面来解释一下通过Flow异步返回多个值。
简单来讲就是协程中的 Flow 通过利用挂起函数和协程的技术,实现了一种异步数据流的处理模型。下面是chatGPT对其中的技术原理解释
-
挂起函数:Flow 使用挂起函数来暂停和恢复数据流的执行。当数据项推送到流中时,流的执行可以通过挂起函数暂停。这样,流能够合理利用协程调度器,继续执行其他任务,而不会阻塞线程。只有当下游准备好接收数据时,流的执行才会重新启动,通过挂起函数的恢复机制从挂起的位置继续执行。
-
协程调度器:Flow 使用协程调度器来管理数据流的并发执行。协程调度器负责协程之间的切换、协程的调度和执行上下文的管理。通过协程调度器,Flow 可以在不同的线程或协程上执行异步任务,以提高并发性能。例如,可以使用 Dispatchers.IO 调度器在 IO 线程上执行阻塞的 IO 操作,而不会阻塞主线程。
-
取消支持:Flow 内置了对取消的支持。当 Flow 的订阅者取消订阅时,Flow 使用挂起函数的取消机制来终止流的执行。这使得我们可以通过取消操作来控制数据流的终止,释放相关资源,并适时地停止数据的推送。
suspend fun Flow() = flow{
for (i in 1..3){
delay(1000)
emit(i)//用于产生元素的
}
}
@Test
fun testFlow() = runBlocking {
//用来显示它是异步非阻塞的,是挂起的
launch {
for (i in 1..3){
println("not blocked $i")
delay(1500)
}
}
Flow().collect{value -> println(value) }
}
其中Flow()前的suspend可以去掉
运行结果: