协程启动 GlobalScope.launch和runBlocking的区别

协程启动

如果想在协程非作用域中启动协程,有两种方法

runBlocking和GlobalScope.launch{}.start()

其中runBlocking会阻塞主线程,直到回调代码执行完毕,该方法不能用来异步启动,只能用来从非协程作用域切换到协程作用域(比如执行suspend块代码)

使用GlobalScope.launch{}.start(),表示在非协程作用域中启动协程,该方法不会阻塞主线程。

执行下操作就能看出区别

fun main(args: Array<String>) {

    println(1)
    runBlocking {
        println("休眠3秒")
        delay(3000)
        println(2)
    }
    println(3)
}

打印顺序:

1
休眠3秒
2
3

---------------------------------------------------

fun main(args: Array<String>) {
    println(1)
    GlobalScope.launch(Dispatchers.IO) {
        println("休眠3秒")
        delay(3000)
        println(2)
    }
    println(3)
    //阻塞主线程4秒,保证GlobalScope运行期间,JVM不会被关闭
    Thread.sleep(4000)
}

打印顺序

1
3
休眠3秒
2

可以看出,runBlocking在执行时会阻塞主线程,直到runBlocking运行结束才执行区域外的代码,而GlobalScope则是两个线程同步执行

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值