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


    一、介绍

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

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

    二、协程suspend

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

    GlobalScope和runBlocking。

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

    案例1.

    1. fun main() {
    2. println("start-------------")
    3. runBlocking {
    4. val text=GlobalScope.async { testLog("send") }
    5. println("text reslut=${text.await()}")
    6. println("text reslut mime")
    7. }
    8. println("end-------------")
    9. }
    10. suspend fun testLog(txt: String): String {
    11. delay(2500)
    12. return "back ${txt}"
    13. }

    结果还是按顺序执行了

    案例2.

    1. fun main() {
    2. println("start-------------")
    3. GlobalScope.async {
    4. runBlocking {
    5. val text=GlobalScope.async { testLog("send") }
    6. println("text reslut=${text.await()}")
    7. println("text reslut mime")
    8. }
    9. }
    10. println("end-------------")
    11. }
    12. suspend fun testLog(txt: String): String {
    13. delay(2500)
    14. return "back ${txt}"
    15. }

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

    案例3.

    1. fun main() {
    2. println("start-------------")
    3. runBlocking {
    4. val text = GlobalScope.async { testLog("send") }
    5. async {
    6. println("text reslut=${text.await()}")
    7. }
    8. println("text reslut mime")
    9. }
    10. println("end-------------")
    11. }
    12. suspend fun testLog(txt: String): String {
    13. delay(2500)
    14. return "back ${txt}"
    15. }

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

    案例4.

    1. fun main() {
    2. println("start-------------")
    3. runBlocking {
    4. async {
    5. println("text reslut 2500=${GlobalScope.async { testLog("send") }.await()}")
    6. }
    7. async {
    8. println("text reslut 1500=${GlobalScope.async { testLog("send",1500) }.await()}")
    9. }
    10. println("text reslut mime")
    11. }
    12. println("end-------------")
    13. }
    14. suspend fun testLog(txt: String,delays:Long=2500): String {
    15. delay(delays)
    16. return "back ${txt}"
    17. }

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

    三、总结

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

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

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

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

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

  • 相关阅读:
    Java——IO流(一)-(6/8):字节流-FileInputStream 每次读取多个字节(示例演示)、一次读取完全部字节(方式一、方式二,注意事项)
    linux查看系统/内核版本号、CPU核数/线程/型号、内存大小等
    基于SpringBoot的共享单车管理系统
    【ShardingSphere】水平分库分表配置方法
    与云idea的初见:知此软件必能成也
    VIM去掉utf-8 bom头
    jQuery 安装
    【python】获取URL_IP
    Revit中【管线倒角】自定义长度
    Dapr 助力应用架构的可持续性
  • 原文地址:https://blog.csdn.net/qq36246172/article/details/138186991