網站首頁 編程語言 正文
協程源碼的結構
在研究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
相關推薦
- 2022-01-11 for循環調用接口返回的數據放在同一個列表中
- 2022-04-09 關于Python中的閉包詳解_python
- 2022-09-15 Android自定義ViewGroup實現選擇面板_Android
- 2022-12-12 python?打印完整異常問題_python
- 2022-06-28 React18之狀態批處理的使用_React
- 2023-01-01 Kotlin?startActivity跳轉Activity實現流程詳解_Android
- 2023-05-30 Python賦值邏輯的實現_python
- 2022-10-12 Python數據分析之使用scikit-learn構建模型_python
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支