协程的原理还是没懂

2020-05-06 23:12:43 +08:00
 winterbells

网上看的文章都是讲了 Kotlin 编译后,有个 continuation,有个状态机 怎么在线程中挂起,又是怎么在耗时操作结束后恢复的有点理解不了 没学过这种底层的东西,看得云里雾里的 qaq

4187 次点击
所在节点    问与答
16 条回复
vk42
2020-05-06 23:43:22 +08:00
简单理解就是把多线程任务挤到同一个线程内,通过协程原语进行交互交替执行,但因为本质是单线程所以省去了同步机制开销。如果你原先对多线程熟悉应该会更方便理解
aabbcc112233
2020-05-06 23:46:51 +08:00
@vk42 所以你知道 kotlin 的协程真的是真协程吗
vk42
2020-05-07 00:40:10 +08:00
@aabbcc112233 kotlin 还真不了解,不同语言实现协程机制肯定有区别,但协程本来就是从汇编就有了的老概念了,实现上也没什么难度,只要概念本质是对的,无所谓真假吧
WebKit
2020-05-07 00:47:38 +08:00
@aabbcc112233 kotlin 的协程只是对线程的封装,类似 rxjava
silvernoo
2020-05-07 01:39:39 +08:00
协程应该就是一种实现把,主要的思想是异步和非阻塞把
lzdhlsc
2020-05-07 05:23:29 +08:00
coroutine == resumable function
winterbells
2020-05-07 08:09:30 +08:00
@vk42 这个知道了,但它是怎么挂起的、怎么 delay 的,又是怎么在一段时间后恢复的,还是不清楚
hanxiV2EX
2020-05-07 08:47:50 +08:00
就跟 c 语言的 goto 差不多,执行到某个地方 yield,函数就 return 了,再 resume 的时候又回到了上次 yield 的地方。只不过协程会帮你把函数堆栈都存好了,goto 回来的时候能继续找到上下文。
ica10888
2020-05-07 08:53:27 +08:00
我想说 callcc,怕直接绕晕了...
129tyc
2020-05-07 09:06:29 +08:00
协程的挂起可以通过 yield 主动放弃对 cpu 的占有,恢复则是由其他协程或调度器主动将其 resume,delay 只是挂起和恢复的组合,功能和效果上和线程的 delay 类似
Cabana
2020-05-07 09:15:30 +08:00
jvm 的 kotlin 协程只是对线程调度的封装而已
jswh
2020-05-07 09:33:04 +08:00
传统意义上的协程是基于生成器的,可以在函数执行中间主动让出 cpu 占用,在下次调用的时候恢复函数上下文从中断的地方恢复执行,常见的语法就是 yield 。生成器语法只是提供了主动让出 cpu 占用的能力,要做到实用的协程一般还要搭配一个调度器,golang 语言自带,php 的 swoole,python tornado 等。同时所有相关库( io,网络等)都要用生成器形式来写在等待的时候让出 cpu,不然也没啥异步能力。
itskingname
2020-05-07 09:40:23 +08:00
如果你看得懂 Python,我写了一篇 Python 相关的: https://mp.weixin.qq.com/s/spayiLNuTnFVOWWeW-jkwQ
vk42
2020-05-07 10:28:58 +08:00
@winterbells
挂起恢复都是具体语言实现细节,你要看你所指的语言特性了。比如汇编可以用 long jump 来实现,c 可以用 goto 实现等等……
wysnylc
2020-05-07 10:40:04 +08:00
协程相关:
[Kotlin 协程真的比 Java 线程更高效吗?]( https://cloud.tencent.com/developer/article/1570462)
[为什么 Java 坚持多线程不选择协程?]( https://www.zhihu.com/question/332042250)
Mrag
2020-11-26 15:18:16 +08:00
与事件驱动的机制很相似

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/669096

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX