kotlin源码结构层次详解
作者:xfhy 发布时间:2022-08-19 14:24:48
协程源码的结构
在研究Kotlin源码之前,得先搞懂Kotlin源码结构分布。不然找不到该看哪里的代码。看源码之前当然先得有一个目标,最好是带着这个目标去看源码才比较有针对性,抓主流程,不然可能会陷入浩瀚的源码细节中。
协程源码,按道理可以分成2个仓库,一个是Kotlin仓库,一个是Kotlin协程仓库。
Kotlin仓库 https://github.com/JetBrains/kotlin
协程仓库 kotlinx.coroutines https://github.com/Kotlin/kotlinx.coroutines
Kotlin仓库中定义了协程的基础元素,这些基础元素非常关键,它们是构建协程的基础。而协程仓库相当于是用Kotlin仓库中定义的基础元素来实现协程的逻辑。
Kotlin协程源码分为3层:
基础层:Kotlin库中定义的协程基础元素。比如CancellationException、CombinedContext、Continuation、ContinuationInterceptor、CoroutineContext、SafeContinuation等。
中间层:协程仓库中,协程框架的通用逻辑kotlinx.coroutine-common。比如Job、Deferred、Select、Channel、Flow。
平台层:协程仓库中,协程在特定平台的实现。如JVM、JS、Native。
下面,我们来详细了解一下这些层是怎么分布的。
基础层
Kotlin库中,协程的基础层具体位置是在/kotlin/libraries/stdlib/src/kotlin/coroutines/
里面。官方把这些基础元素放标准库里面,是为了解耦。
通过这些基础元素可以组合成各种协程框架,虽然目前是官方的协程框架组合的最好。
在基础层定义好了API之后,协程库在各自的平台层才好有规可循,在这些API下面开发平台相关的代码。
中间层
在kotlin.coroutines库中的/kotlinx.coroutines/kotlinx-coroutines-core/common/
子模块下,是一些公共的逻辑。比如launch、async、withContext、Deferred、Job、NonCancellable、Channel、Flow、AbstractCoroutine,这些东西是对基础层的元素进行的封装,使上手协程更容易。
在这些公共逻辑的源码里,是不涉及平台相关的逻辑的。
平台层
因为Kotlin是跨平台的,所以它的平台相关的逻辑又分为了js、jvm、native,它们的目录与common平级,分别是:
js:kotlinx-coroutines-core/js/
jvm:kotlinx-coroutines-core/jvm/
native:kotlinx-coroutines-core/native/
我们重点关注一下jvm的就行,下面是jvm目录下的代码,其他平台也需要实现其自己的线程池、事件循环、异步任务等。
.
├── AbstractTimeSource.kt
├── Builders.kt
├── CoroutineContext.kt
├── CoroutineExceptionHandlerImpl.kt
├── Debug.kt
├── DebugStrings.kt
├── DefaultExecutor.kt
├── Dispatchers.kt
├── EventLoop.kt //事件循环
├── Exceptions.kt
├── Executors.kt
├── Future.kt
├── Interruptible.kt
├── Runnable.kt //java.lang.Runnable
├── SchedulerTask.kt
├── ThreadContextElement.kt //线程池
├── ThreadPoolDispatcher.kt
├── channels
│ ├── Actor.kt
│ └── TickerChannels.kt
├── debug
│ ├── AgentPremain.kt
│ └── internal
│ ├── AgentInstallationType.kt
│ ├── ConcurrentWeakMap.kt
│ ├── DebugCoroutineInfo.kt
│ ├── DebugCoroutineInfoImpl.kt
│ ├── DebugProbes.kt
│ ├── DebugProbesImpl.kt
│ ├── DebuggerInfo.kt
│ └── StackTraceFrame.kt
├── flow
│ └── internal
│ ├── FlowExceptions.kt
│ └── SafeCollector.kt
├── internal
│ ├── Concurrent.kt
│ ├── ExceptionsConstructor.kt
│ ├── FastServiceLoader.kt
│ ├── InternalAnnotations.kt
│ ├── LocalAtomics.kt
│ ├── MainDispatchers.kt
│ ├── ProbesSupport.kt
│ ├── ResizableAtomicArray.kt
│ ├── StackTraceRecovery.kt
│ ├── Synchronized.kt
│ ├── SystemProps.kt
│ ├── ThreadContext.kt
│ └── ThreadLocal.kt //java.lang.ThreadLocal
└── scheduling
├── CoroutineScheduler.kt
├── Deprecated.kt
├── Dispatcher.kt
├── Tasks.kt
└── WorkQueue.kt
来源:https://github.com/xfhy/Android-Notes/blob/master/Blogs/Kotlin/0.Kotlin
猜你喜欢
- 网络编程TCP实现聊天的前提还需要掌握IO流,话不多说,直接上代码!客户端:package com.kuang.lesson02;impor
- 这是我们用得比较多的一种设计模式,也是23种标准设计模式之一,使用前面讲的简单工厂设计模式,遇到具体产品经常变换时就不太适合了,违反了开闭设
- 在很多项目中,为了安全安全考虑,需要对数据包进行加密处理,本文实例所述的即为C#加密代码,在应用开发中有很大的实用价值。说起数据包加密,其实
- 和线程停止相关的三个方法/*中断线程。如果线程被wait(),join(),sleep()等方法阻塞,调用interrupt()会清除线程中
- 在一些场合,我们往往需要使用印章来给每页文档加盖一个印章,以表示该文档经过某个部门的认证的,常规的做法就是打印文档后盖章,如果需要电子档再行
- 一、什么是JMSJMS即Java消息服务(Java Message Service)应用程序接口,是一个Java平台中关于面向消息中间件(M
- 线程中start方法与run方法的区别在线程中,如果start方法依次调用run方法,为什么我们会选择去调用start方法?或者在java线
- json格式的字符串与对象的互相转换Jackson 简介Jackson是一个简单基于Java应用库,Jackson可以轻松的将Java对象转
- 一、项目简述功能: 主页显示商品; 所有蛋糕商品展示,可进行商品搜索; 点击商品进入商品详情页,具有立即购买功能,可增减购买商品数量亦可手动
- 一、项目背景在实际工作中,会遇到业务比较集中的情况,随着时间推延,这部分业务关联的mysql表就会越来越大,十分臃肿。尽管在项目架构上做了读
- 本文实例汇总了Java的System.getProperty()方法获取信息的用法。分享给大家供大家参考。具体如下:System.out.p
- 1.基本思路我现阶段的分页查询的实现是基于sql语句的。select * from user where id limit a, b构造出相
- MyBatis是一个优秀的持久层框架,它对jdbc的操作数据库的过程进行封装,使开发者只需要关注SQL本身,而不需要花费精力去处理例如注册驱
- maven导入依赖<dependencies> <dependency> &
- 本文实例为大家分享了Unity实现切割图集工具的具体代码,供大家参考,具体内容如下操作步骤先将脚本拖入Editor1.选中要切割的图片,te
- Android权限Android安全架构规定:默认情况下,任何应用都没有权限执行对其他应用、操作系统或用户有不利影响的任何操作。这包括读写用
- 当我们需要与 NIO Channel 进行交互时, 我们就需要使用到 NIO Buffer, 即数据从 Buffer读取到 Channel
- 题目:使用栈计算类似表达式:5+2*3-2 的计算结果 提示:简易计算器操作符号限于+,-,*,/的计算分析思路:1、
- Chart折线图使用鼠标滚轮放大、缩小和平移曲线使用鼠标滚轮滚动放大和缩小X轴的宽度,鼠标左键按住拖动实现曲线的左右平移,不再使用滚动条。添
- 什么是包包 (package) 是组织类的一种方式.使用包的主要目的是保证类的唯一性.例如, 你在代码中写了一个 Test 类. 然后你的同