Kotlin Coroutines中你这七个错误你避免了吗

本文列举了在使用Kotlin Coroutines时容易犯的七个错误,包括错误地实例化Job、不当使用SupervisorJob、不支持取消、不必要的调度器切换、尝试用try/catch处理异常、在子协程中使用CoroutineExceptionHandler以及错误地捕获CancellationExceptions。理解并避免这些错误能帮助开发者更好地利用Kotlin Coroutines进行并发编程。
摘要由CSDN通过智能技术生成

我看来,Kotlin Coroutines(协程) 大大简化了同步和异步代码。但是,我发现了许多开发者在使用协程时会犯一些通用性的错误。

  1. 在使用协程时实例化一个新的 Job 实例
    有时候你会需要一个 job 来对协程进行一些操作,例如,稍后取消。另外由于协程构建器 launch{} 和 async{} 都需要 job 作为入参,你可能会想到创建一个新的 job 实例作为参数来使用。这样的话,你就拥有了一个 job 引用,稍后你可以调用它的 .cancel() 方法。
fun main() = runBlocking {
   

    val coroutineJob = Job()
    launch(coroutineJob) {
   
        println("performing some work in Coroutine")
        delay(100)
    }.invokeOnCompletion {
    throwable ->
        if (throwable is CancellationException) {
   
            println("Coroutine was cancelled")
        }
    }

    // cancel job while Coroutine performs work
    delay(50)
    coroutineJob.cancel()
}

这段代码看起来没有任何问题,协程被成功取消了。

>_ 

performing some work in Coroutine
Coroutine was cancelled

Process finished with exit code 0

但是,让我们试试在协程作用域 CoroutineScope 中运行这个协程,然后取消协程作用域而不是协程的 job 。

fun main() = runBlocking {
   

    val scopeJob = Job()
    val scope = CoroutineScope(scopeJob)

    val coroutineJob = Job()
    scope.launch(coroutineJob)</
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值