Kotlin:协程基础

第一个协程程序
复制代码
import kotlinx.coroutines.*

fun main(){
    GlobalScope.launch {
        delay(1000L)//delay 是一个特殊的 挂起函数 ,它不会造成线程阻塞,但是会 挂起 协程,并且只能在协程中使用。
        println("World!")
    }
    println("Hello - ")// 主线程中的代码会立即执行
    Thread.sleep(2000L) // 阻塞主线程 2 秒钟来保证 JVM 存活

//    runBlocking {//但是这个表达式阻塞了主线程
//        delay(2000L)//我们延迟 2 秒来保证 JVM 的存活
//    }
}

本质上,协程是轻量级的线程。 它们在某些 CoroutineScope 上下文中与 launch 协程构建器 一起启动。 这里我们在 GlobalScope 中启动了一个新的协程,这意味着新协程的生命周期只受整个应用程序的生命周期限制。

可以将 GlobalScope.launch { ...... } 替换为 thread { ...... },并将 delay(......) 替换为 Thread.sleep(......) 达到同样目的。 试试看(不要忘记导入 kotlin.concurrent.thread)。

如果你首先将 GlobalScope.launch 替换为 thread,编译器会报以下错误:

Error: Kotlin: Suspend functions are only allowed to be called from a coroutine or another suspend function

这是因为 delay 是一个特殊的 挂起函数 ,它不会造成线程阻塞,但是会 挂起 协程,并且只能在协程中使用。

相关推荐
小明9133 分钟前
基于Rokid CXR-M SDK的AI饮食健康助手开发实战
前端
一枚前端小姐姐3 分钟前
低代码平台表单设计系统技术分析(实战三)
前端·vue.js·低代码
牛奶4 分钟前
ts随笔:面向对象与高级类型
前端·面试·typescript
牛奶5 分钟前
React 基础理论 & API 使用
前端·react.js·面试
大漠_w3cpluscom8 分钟前
别再死记CSS属性了!真正能让你少走半年弯路的,是这套思维
前端
兆子龙28 分钟前
用 React + Remotion 做视频:入门与 AI 驱动生成
前端·架构
SuperEugene32 分钟前
从 Vue2 到 Vue3:语法差异与迁移时最容易懵的点
前端·vue.js·面试
鼓浪屿35 分钟前
vue3:组件中,v-model的区别(新版)
前端
Leon1 小时前
新手引导 intro.js 的使用
前端·javascript·vue.js
Zeros1 小时前
Claude Code 使用心得 - 从尝鲜到日常的进阶之路
前端