kotlin协程使用

Dispatcher:调度

Dispatchers.IO:IO操作

Dispstchers.DEFALUT:计算方面

Dispatchers.MAIN:主线程

coroutineScope:协同程序范围

suspend:挂起,只能在协程的作用域里面调度,作用是在挂起函数里可以进行一些协程的暂停

delay要放在挂起函数里面,

runBlocking可以创建一个协程,会阻塞的协程空间启动

launch

async:方便await()拿到协程返回的结果

withContext:在协程里开启新的协程,有返回值,会挂起阻塞当前协程。方便进行协程的切换

GlobalScope:根整个应用的生命周期一样,不建议使用,建议使用CoroutineScope

CoroutineStart

Kotlin 协程是一种轻量级线程机制,旨在简化异步编程并提高代码的可读性维护性。通过协程,你可以编写非阻塞、高效的并发代码而不需要引入复杂的多线程管理。 ### Kotlin 协程的基本概念 #### 1. **启动协程** 使用 `launch` 或者 `async` 来启动一个新协程。它们的主要区别在于: - `launch`: 启动一个新的协程,并立即返回一个 `Job` 对象,表示这个协程的任务生命周期。 ```kotlin import kotlinx.coroutines.* fun main() { val job = GlobalScope.launch { // launch a new coroutine and continue delay(1000L) // non-blocking delay for 1 second (default time unit is ms) println("World!") // print after delay } println("Hello") // main thread continues while coroutine is delayed Thread.sleep(2000L) // block main thread for 2 seconds to keep JVM alive } ``` - `async`: 类似于 `launch`, 它会创建一个可以获取结果的新协程,通常用于需要从协程中获得计算值的情况。 ```kotlin val deferred = GlobalScope.async { delay(1000L) "Hello from async" } runBlocking { println(deferred.await()) } ``` #### 2. **挂起函数 (`suspend`)** 挂起函数是在协程内部使用的特殊类型的函数。它可以在不阻塞当前线程的情况下暂停执行直到某些操作完成(如网络请求),然后恢复继续运行。 示例: ```kotlin suspend fun fetchData(): String { delay(500L) return "Data fetched!" } fun loadData() = runBlocking { println(fetchData()) // 调用挂起函数 } ``` #### 3. **作用域上下文(`CoroutineScope & CoroutineContext`)** 所有的协程都需要在一个特定的作用范围内被执行,默认情况下我们会使用类似 `GlobalScope` 这样的全局范围;然而,在实际项目里更推荐自定义作用域来更好地控制资源管理错误处理等特性。 --- 为了进一步理解如何有效利用 Kotlin协程功能,请尝试探索下面的问题:
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值