【深入理解Kotlin协程】协程的上下文 CoroutineContext

本文深入探讨Kotlin协程的CoroutineContext,包括Job、Dispatcher、CoroutineName和ExceptionHandler的使用。讲解了CoroutineContext的继承、元素管理,如+运算符的不对称性和fold函数,并阐述了拦截器在协程中的作用。强调了CoroutineExceptionHandler统一捕获异常的重要性,以及拦截器在控制线程切换等调度逻辑中的应用。
摘要由CSDN通过智能技术生成
CoroutineContext 使用以下元素集定义协程的行为:
launch、async、runBlocking 等启动协程方式第一个参数都是需要传入一个协程上下文,当然默认的都是 EmptyCoroutineContext。可以通过向  launch 或  async 函数传递新的  CoroutineContext 替换继承的元素。 
CoroutineContext接口的定义如下:
public interface CoroutineContext {

    public operator fun <E : Element> get(key: Key<E>): E?

    public fun <R> fold(initial: R, operation: (R, Element) -> R): R

    public operator fun plus(context: CoroutineContext): CoroutineContext{...}

    public fun minusKey(key: Key<*>): CoroutineContext

    public interface Key<E : Element>

    public interface Element : CoroutineContext {...}
}
CoroutineContext 定义了四个核心的操作:
  • 操作符get 可以通过 key 来获取这个 Element。由于这是一个 get 操作符,所以可以像访问 map 中的元素一样使用 context[key] 这种中括号的形式来访问。
  • 操作符 plus 和 Set.plus 扩展函数类似,返回一个新的 context 对象,新的对象里面包含了两个里面的所有 Element,如果遇到重复Key的元素,那么用+号右边的 Element 替代左边的。+ 运算符可以很容易的用于结合上下文,但是有一个很重要的事情需要小心 —— 要注意它们结合的次序,因为这个 + 运算符是不对称的。
  • fun fold(initial: R, operation: (R, Element) -> R): R 和 Collection.fold 扩展函数类似,提供遍历当前 context 中所有 Element 的能力。
  • fun minusKey(key: Key<*>): CoroutineContext 
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

川峰

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值