kotlin协程runBlocking 阻塞线程

runBlocking在Kotlin中用于创建一个阻塞调用,它会等待内部所有相同作用域的协程完成后再继续执行后续代码。在这个例子中,三个并发的协程launchA、launchB和launchC交叉执行,但runBlocking确保它们全部结束才会打印end--,展示了非阻塞协程与阻塞调用的结合使用。
摘要由CSDN通过智能技术生成

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 本身阻塞线程,但内部运行的协程又非阻塞。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zhangphil

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值