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异步执行模块。

相关推荐
lpfasd1231 分钟前
TypeScript + Cloudflare 全家桶部署项目全流程
前端·javascript·typescript
ZC跨境爬虫5 分钟前
极验滑动验证码自动化实战:背景提取、缺口定位与Playwright滑动模拟
前端·爬虫·python·自动化
前端Hardy21 分钟前
字节/腾讯内部流出!Claude Code 2026王炸玩法!效率暴涨10倍
前端·javascript·vue.js
糟糕好吃27 分钟前
AI 全流程解析(LLM / Token / Context / RAG / Prompt / Tool / Skill / Agent)
前端·后端·设计模式
快手技术32 分钟前
快手广告系统全面迈入生成式推荐时代!GR4AD:从Token到Revenue的全链路重构
前端·后端
前端Hardy33 分钟前
大厂都在偷偷用的 Cursor Rules 封装!告别重复 Prompt,AI 编程效率翻倍
前端·javascript·面试
kyriewen34 分钟前
Vite:比Webpack快100倍的“闪电侠”,原理竟然这么简单?
前端·javascript·vite
竹林81835 分钟前
RainbowKit快速集成多链钱包连接:从“连不上”到丝滑切换的踩坑实录
前端·javascript
小小小小宇1 小时前
前端看go并发
前端
前端Hardy1 小时前
Cursor Rules 完全指南(2026 最新版)
前端·javascript·面试