在 Kotlin 中,實(shí)現(xiàn)并發(fā)主要依賴于協(xié)程(coroutines)。協(xié)程是一種輕量級(jí)的線程,它允許你編寫異步代碼,而無(wú)需處理線程或線程池。Kotlin 提供了強(qiáng)大的協(xié)程庫(kù),使得編寫并發(fā)代碼變得簡(jiǎn)單而高效。
以下是如何使用 Kotlin 協(xié)程實(shí)現(xiàn)并發(fā)的幾個(gè)關(guān)鍵概念:
引入?yún)f(xié)程依賴:
在你的 build.gradle
文件中添加 Kotlin 協(xié)程庫(kù)的依賴:
dependencies {
implementation 'org.jetbrains.kotlinx:kotlinx-coroutines-core:1.6.0'
}
創(chuàng)建協(xié)程作用域:
使用 CoroutineScope
創(chuàng)建一個(gè)協(xié)程作用域,以便在其中啟動(dòng)和管理協(xié)程。你可以使用 GlobalScope
或自定義的作用域。
val scope = CoroutineScope(Dispatchers.Default)
啟動(dòng)協(xié)程:
使用 launch
或 async
函數(shù)啟動(dòng)協(xié)程。launch
用于非阻塞的異步任務(wù),而 async
用于可以返回結(jié)果的異步任務(wù)。
scope.launch {
// 異步任務(wù)代碼
}
使用 Dispatchers
:
Kotlin 提供了不同的調(diào)度器(dispatchers),如 Dispatchers.Default
、Dispatchers.IO
和 Dispatchers.Main
。你可以根據(jù)需要選擇合適的調(diào)度器來(lái)執(zhí)行協(xié)程。
scope.launch(Dispatchers.IO) {
// 執(zhí)行 I/O 密集型任務(wù)
}
處理結(jié)果:
如果你使用 async
啟動(dòng)了一個(gè)返回結(jié)果的協(xié)程,可以使用 await()
函數(shù)獲取結(jié)果。
val result = scope.async(Dispatchers.IO) {
// 執(zhí)行 I/O 密集型任務(wù)并返回結(jié)果
}.await()
取消協(xié)程:
你可以使用 cancel
函數(shù)取消協(xié)程。一旦協(xié)程被取消,它將停止執(zhí)行并拋出 CancellationException
。
val job = scope.launch {
// 異步任務(wù)代碼
}
// 取消協(xié)程
job.cancel()
以下是一個(gè)完整的示例,展示了如何使用 Kotlin 協(xié)程實(shí)現(xiàn)并發(fā):
import kotlinx.coroutines.*
fun main() = runBlocking {
val scope = CoroutineScope(Dispatchers.Default)
val jobs = List(10) {
scope.launch(Dispatchers.IO) {
performTask("Task $it")
}
}
jobs.forEach { it.join() }
}
suspend fun performTask(task: String): String {
delay(1000L) // 模擬 I/O 操作
println("$task completed")
return task
}
在這個(gè)示例中,我們創(chuàng)建了一個(gè)協(xié)程作用域,并在其中啟動(dòng)了 10 個(gè)異步任務(wù)。每個(gè)任務(wù)都在 Dispatchers.IO
上執(zhí)行,模擬 I/O 操作。最后,我們使用 join
函數(shù)等待所有任務(wù)完成。