kotlin的runBlocking 当内部相同作用域的所有协程都运行结束后,在 runBlocking 之后的代码才能执行, runBlocking 会阻塞所在线程。
例如:
import kotlinx.coroutines.delay
import kotlinx.coroutines.launch
import kotlinx.coroutines.runBlocking
fun main() {
println("start--")
runBlocking {
launch {
repeat(3) {
delay(100)
println("launch A - $it")
}
}
launch {
repeat(3) {
delay(100)
println("launch B - $it")
}
}
launch {
repeat(3) {
delay(100)
println("launch C - $it")
}
}
}
println("end--")
}
输出:
start--
launch A - 0
launch B - 0
launch C - 0
launch A - 1
launch B - 1
launch C - 1
launch A - 2
launch B - 2
launch C - 2
end--
runBlocking 内部启动的3个协程做耗时操作,从输出可以看到3个协程交叉并发执行,runBlocking 会等到3个协程执行结束后才退出,输出结果有明确先后顺序。runBlocking 内部的协程是非阻塞的,但runBlocking阻塞所在的线程。runBlocking 会等待相同作用域的协程完成才退出runBlocking 本身阻塞线程,但内部运行的协程又非阻塞。