- Kotlin Coroutines(协程) 完全解析(二),深入
- Kotlin Coroutines(协程) 完全解析(三),封装
- Kotlin Coroutines(协程) 完全解析(四),协程
- Kotlin Coroutines(协程) 完全解析(五),协程
- Kotlin Coroutines 协程实现原理全解析
- Androdi kotlin Coroutines(协程)详解
- Androdi kotlin Coroutines(协程)详解
- Androdi kotlin Coroutines(协程)详解
- Androdi kotlin Coroutines(协程)详解
- Androdi kotlin Coroutines(协程)详解
data:image/s3,"s3://crabby-images/e7074/e707441af38b19690b705beb046fc3e31b64ed3a" alt=""
data:image/s3,"s3://crabby-images/f36e1/f36e1fa034fe8e21d0b2f4005f30eba86fb62018" alt=""
Hello Coroutines World
package coroutines.demo
import kotlinx.coroutines.coroutineScope
import kotlinx.coroutines.delay
import kotlinx.coroutines.launch
suspend fun main() = coroutineScope {
launch {
delay(1000)
println("Kotlin Coroutines World!")
}
println("Hello")
}
输出:
Hello
Kotlin Coroutines World!
CoroutineScope
public interface CoroutineScope {
/**
* The context of this scope.
* Context is encapsulated by the scope and used for implementation of coroutine builders that are extensions on the scope.
* Accessing this property in general code is not recommended for any purposes except accessing the [Job] instance for advanced usages.
*
* By convention, should contain an instance of a [job][Job] to enforce structured concurrency.
*/
public val coroutineContext: CoroutineContext
}
CoroutineContext : Persistent context for the coroutine
package kotlin.coroutines
/**
* Persistent context for the coroutine. It is an indexed set of [Element] instances.
* An indexed set is a mix between a set and a map.
* Every element in this set has a unique [Key].
*/
@SinceKotlin("1.3")
public interface CoroutineContext {
/**
* Returns the element with the given [key] from this context or `null`.
*/
public operator fun <E : Element> get(key: Key<E>): E?
/**
* Accumulates entries of this context starting with [initial] value and applying [operation]
* from left to right to current accumulator value and each element of this context.
*/
public fun <R> fold(initial: R, operation: (R, Element) -> R): R
/**
* Returns a context containing elements from this context and elements from other [context].
* The elements from this context with the same key as in the other one are dropped.
*/
public operator fun plus(context: CoroutineContext): CoroutineContext =
if (context === EmptyCoroutineContext) this else // fast path -- avoid lambda creation
context.fold(this) { acc, element ->
val removed = acc.minusKey(element.key)
if (removed === EmptyCoroutineContext) element else {
// make sure interceptor is always last in the context (and thus is fast to get when present)
val interceptor = removed[ContinuationInterceptor]
if (interceptor == null) CombinedContext(removed, element) else {
val left = removed.minusKey(ContinuationInterceptor)
if (left === EmptyCoroutineContext) CombinedContext(element, interceptor) else
CombinedContext(CombinedContext(left, element), interceptor)
}
}
}
/**
* Returns a context containing elements from this context, but without an element with
* the specified [key].
*/
public fun minusKey(key: Key<*>): CoroutineContext
/**
* Key for the elements of [CoroutineContext]. [E] is a type of element with this key.
*/
public interface Key<E : Element>
/**
* An element of the [CoroutineContext]. An element of the coroutine context is a singleton context by itself.
*/
public interface Element : CoroutineContext {
/**
* A key of this coroutine context element.
*/
public val key: Key<*>
public override operator fun <E : Element> get(key: Key<E>): E? =
@Suppress("UNCHECKED_CAST")
if (this.key == key) this as E else null
public override fun <R> fold(initial: R, operation: (R, Element) -> R): R =
operation(initial, this)
public override fun minusKey(key: Key<*>): CoroutineContext =
if (this.key == key) EmptyCoroutineContext else this
}
}
Continuation
package kotlin.coroutines
import kotlin.contracts.*
import kotlin.coroutines.intrinsics.*
import kotlin.internal.InlineOnly
/**
* Interface representing a continuation after a suspension point that returns a value of type `T`.
*/
@SinceKotlin("1.3")
public interface Continuation<in T> {
/**
* The context of the coroutine that corresponds to this continuation.
*/
public val context: CoroutineContext
/**
* Resumes the execution of the corresponding coroutine passing a successful or failed [result] as the
* return value of the last suspension point.
*/
public fun resumeWith(result: Result<T>)
}
CombinedContext
//--------------------- internal impl ---------------------
// this class is not exposed, but is hidden inside implementations
// this is a left-biased list, so that `plus` works naturally
@SinceKotlin("1.3")
internal class CombinedContext(
private val left: CoroutineContext,
private val element: Element
) : CoroutineContext, Serializable {
override fun <E : Element> get(key: Key<E>): E? {
var cur = this
while (true) {
cur.element[key]?.let { return it }
val next = cur.left
if (next is CombinedContext) {
cur = next
} else {
return next[key]
}
}
}
public override fun <R> fold(initial: R, operation: (R, Element) -> R): R =
operation(left.fold(initial, operation), element)
public override fun minusKey(key: Key<*>): CoroutineContext {
element[key]?.let { return left }
val newLeft = left.minusKey(key)
return when {
newLeft === left -> this
newLeft === EmptyCoroutineContext -> element
else -> CombinedContext(newLeft, element)
}
}
private fun size(): Int {
var cur = this
var size = 2
while (true) {
cur = cur.left as? CombinedContext ?: return size
size++
}
}
private fun contains(element: Element): Boolean =
get(element.key) == element
private fun containsAll(context: CombinedContext): Boolean {
var cur = context
while (true) {
if (!contains(cur.element)) return false
val next = cur.left
if (next is CombinedContext) {
cur = next
} else {
return contains(next as Element)
}
}
}
override fun equals(other: Any?): Boolean =
this === other || other is CombinedContext && other.size() == size() && other.containsAll(this)
override fun hashCode(): Int = left.hashCode() + element.hashCode()
override fun toString(): String =
"[" + fold("") { acc, element ->
if (acc.isEmpty()) element.toString() else "$acc, $element"
} + "]"
private fun writeReplace(): Any {
val n = size()
val elements = arrayOfNulls<CoroutineContext>(n)
var index = 0
fold(Unit) { _, element -> elements[index++] = element }
check(index == n)
@Suppress("UNCHECKED_CAST")
return Serialized(elements as Array<CoroutineContext>)
}
private class Serialized(val elements: Array<CoroutineContext>) : Serializable {
companion object {
private const val serialVersionUID: Long = 0L
}
private fun readResolve(): Any = elements.fold(EmptyCoroutineContext, CoroutineContext::plus)
}
}
data:image/s3,"s3://crabby-images/9f762/9f762d3784b11f50bf56a73d3167d857bf0aa824" alt=""
data:image/s3,"s3://crabby-images/ab200/ab20079e2c149c7deb15d9f285968a1e4e5142ae" alt=""
data:image/s3,"s3://crabby-images/2d7fa/2d7fa613538a0f3d9af66801982c541b5033896d" alt=""
data:image/s3,"s3://crabby-images/603fb/603fbd57f0340ca261e254d2746c64394a88019a" alt=""
data:image/s3,"s3://crabby-images/f746e/f746eb4c9b9528fcb42caa57caa2af7c63d41b41" alt=""
data:image/s3,"s3://crabby-images/fd87e/fd87e8b0cbf7bc465ab68ac9634ee7c051bb1138" alt=""
data:image/s3,"s3://crabby-images/cefa8/cefa8d9fa366b46fbf4f17159fa86c2b2ab1b589" alt=""
data:image/s3,"s3://crabby-images/05945/05945068b77809997307569ab5abf33a1e816826" alt=""
data:image/s3,"s3://crabby-images/788fd/788fd54c3f6c075f2770232876fdd4cfa7c46314" alt=""
data:image/s3,"s3://crabby-images/633d7/633d72b29c614937cea80476a54c9606caee250e" alt=""
data:image/s3,"s3://crabby-images/6013c/6013cb9ce148b63b02f272bb2edb927a0378504e" alt=""
data:image/s3,"s3://crabby-images/12939/1293927290c32cc76a5ec7721ca80de09e64acdc" alt=""
data:image/s3,"s3://crabby-images/c5529/c552968acb01f974cb4d4e755b5a61f69c9ad3e1" alt=""
data:image/s3,"s3://crabby-images/a3386/a3386ce7876419277c8e9dc1e933db7590d3b8af" alt=""
data:image/s3,"s3://crabby-images/70013/7001338017656042c971b6ebf5c9a5a56f3fa6e3" alt=""
data:image/s3,"s3://crabby-images/20591/20591717c9de4025b38182c8fd09176c43824993" alt=""
data:image/s3,"s3://crabby-images/8ac07/8ac07974ad1fcdcd4cc5a72335da9454e83fbae1" alt=""
data:image/s3,"s3://crabby-images/da6b9/da6b91046f98c7198553830307e81459f4e62279" alt=""
data:image/s3,"s3://crabby-images/d14e4/d14e4118bb00a18a999bff62d8a4891095aff467" alt=""
data:image/s3,"s3://crabby-images/1abd8/1abd8a52d4fff09004e22d7f326deaf05d1dd83f" alt=""
data:image/s3,"s3://crabby-images/1f805/1f8052f8370cf2c9be13cd023ca293e38627aab4" alt=""
data:image/s3,"s3://crabby-images/77624/7762454c40c9bb227c517993025bbf172f6a9e81" alt=""
data:image/s3,"s3://crabby-images/45487/4548705e58ee286cb68344878e54c553576d6bbd" alt=""
网友评论