Android kotlin 协程异步async与await介绍与使用

一、介绍

在kotlin语言中,协程是一个处理耗时的操作,但是很多人都知道同步和异步,但是不知道该如何正确的使用,如果处理不好,看似异步,其实在runBloacking模块中使用的结果是同步的。

针对如何同步和如何异步操作,接下来我会通过案例进行介绍

二、协程suspend

在kotlin中,如果方法被修饰了suspend,那么这个方法必须在协程中执行,常见的处理协程的有

复制代码
GlobalScope和runBlocking。

但是,单层的协程还是会由阻塞的情况

案例1.

Kotlin 复制代码
fun main() {
    println("start-------------")
    runBlocking {
        val text=GlobalScope.async { testLog("send") }
        println("text reslut=${text.await()}")

        println("text reslut mime")
    }
    println("end-------------")
}


suspend fun testLog(txt: String): String {

    delay(2500)
    return "back ${txt}"
}

结果还是按顺序执行了

案例2.

Kotlin 复制代码
fun main() {
    println("start-------------")

    GlobalScope.async {
        runBlocking {
            val text=GlobalScope.async { testLog("send") }
            println("text reslut=${text.await()}")

            println("text reslut mime")
        }
    }

    println("end-------------")
}


suspend fun testLog(txt: String): String {

    delay(2500)
    return "back ${txt}"
}

在runBlocking最外层加了一个异步的,结果runblocking没有执行。

案例3.

Kotlin 复制代码
fun main() {
    println("start-------------")


    runBlocking {
        val text = GlobalScope.async { testLog("send") }
        async {
            println("text reslut=${text.await()}")
        }

        println("text reslut mime")
    }


    println("end-------------")
}


suspend fun testLog(txt: String): String {

    delay(2500)
    return "back ${txt}"
}

结果:在runBlocking中,async{}模块中进行了等待,进行了异步数据返回。

案例4.

Kotlin 复制代码
fun main() {
    println("start-------------")


    runBlocking {

        async {
            println("text reslut 2500=${GlobalScope.async { testLog("send") }.await()}")
        }
        async {
            println("text reslut 1500=${GlobalScope.async { testLog("send",1500) }.await()}")
        }
        println("text reslut mime")
    }


    println("end-------------")
}


suspend fun testLog(txt: String,delays:Long=2500): String {

    delay(delays)
    return "back ${txt}"
}

结果:和我们设置的预期一致,耗时完顺手一致。

三、总结

通过以上几个案例,可以发现

1.异步如果不在runBlocking模块中进行,或者runBlocking模块外面再包一层,会引起最里面的模块,甚至方法体不在执行

2.想要异步执行,必须在runBlocking中对异步结果进行异步,否则达不到异步效果,变成了同步

3.整个函数的外面都是一个同步阻塞的,runBlocking一旦执行,下面的代码处于一个等待的状态

4.runBlocking中可以继续嵌套runBlocking异步执行模块。

相关推荐
XiaoYu20028 分钟前
第8章 Three.js入门
前端·javascript·three.js
这个一个非常哈18 分钟前
element之,自定义form的label
前端·javascript·vue.js
PoppyBu20 分钟前
Ubuntu20.04版本上安装最新版本的scrcpy工具
android·ubuntu
执念、坚持29 分钟前
Property Service源码分析
android
阿东在coding33 分钟前
Flutter 测试框架对比指南
前端
是李嘉图呀37 分钟前
npm推送包失败需要Two-factor权限认证问题解决
前端
自己记录_理解更深刻38 分钟前
本地完成「新建 GitHub 仓库 react-ts-demo → 关联本地 React+TS 项目 → 提交初始代码」的完整操作流程
前端
用户416596736935538 分钟前
在 ViewPager2 + Fragment 架构中玩转 Jetpack Compose
android
借个火er39 分钟前
Chrome 插件开发实战:5 分钟上手 + 原理深度解析
前端
攀登的牵牛花40 分钟前
前端向架构突围系列 - 架构方法(一):概述 4+1 视图模型
前端·设计模式·架构