本文链接: https://blog.youkuaiyun.com/feather_wch/article/details/131526269
startCoroutine
传统startCoroutine是无Receiver版本
public fun <T> (suspend () -> T).startCoroutine(
completion: Continuation<T>
) {
createCoroutineUnintercepted(completion).intercepted().resume(Unit)
}
代码实例:startCoroutine
// 参数为 suspend () -> T
suspend {
// 运行在default线程 DefaultDispatcher-worker-1
println("${Thread.currentThread().name}")
queryInfo()
}.startCoroutine(object : Continuation<Any> {
override val context: CoroutineContext get() = Dispatchers.IO
override fun resumeWith(result: Result<Any>) {
// 运行在default线程 DefaultDispatcher-worker-1
println("${Thread.currentThread().name}")
println(result.getOrNull())
}
})
Receiver详解
startCoroutine具有 Receiver 版本的定义
public fun <R, T> (suspend R.() -> T).startCoroutine(
receiver: R,
completion: Continuation<T>
) {
createCoroutineUnintercepted(receiver, completion).intercepted().resume(Unit)
}
@RestrictsSuspension
class MyScope
suspend fun MyScope.suspendAction():

本文详细介绍了Kotlin协程中的startCoroutine函数,包括无Receiver和Receiver版本的使用,以及挂起和恢复的原理。通过示例代码展示了如何使用Receiver版本的startCoroutine,并解释了Continuation的CoroutineContext的作用。同时,文章还手动实现了挂起和恢复的过程,以帮助理解协程的工作机制。
最低0.47元/天 解锁文章
2218

被折叠的 条评论
为什么被折叠?



