300
V2EX  ›  问与答

协程的原理还是没懂

  •  
  •   300 · May 6, 2020 · 5204 views
    This topic created in 2238 days ago, the information mentioned may be changed or developed.

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

    16 replies    2020-11-26 15:18:16 +08:00
    vk42
        1
    vk42  
       May 6, 2020   ❤️ 2
    简单理解就是把多线程任务挤到同一个线程内,通过协程原语进行交互交替执行,但因为本质是单线程所以省去了同步机制开销。如果你原先对多线程熟悉应该会更方便理解
    aabbcc112233
        2
    aabbcc112233  
       May 6, 2020
    @vk42 所以你知道 kotlin 的协程真的是真协程吗
    vk42
        3
    vk42  
       May 7, 2020
    @aabbcc112233 kotlin 还真不了解,不同语言实现协程机制肯定有区别,但协程本来就是从汇编就有了的老概念了,实现上也没什么难度,只要概念本质是对的,无所谓真假吧
    WebKit
        4
    WebKit  
       May 7, 2020 via Android   ❤️ 1
    @aabbcc112233 kotlin 的协程只是对线程的封装,类似 rxjava
    silvernoo
        5
    silvernoo  
       May 7, 2020   ❤️ 1
    协程应该就是一种实现把,主要的思想是异步和非阻塞把
    lzdhlsc
        6
    lzdhlsc  
       May 7, 2020   ❤️ 1
    coroutine == resumable function
    300
        7
    300  
    OP
       May 7, 2020 via Android
    @vk42 这个知道了,但它是怎么挂起的、怎么 delay 的,又是怎么在一段时间后恢复的,还是不清楚
    hanxiV2EX
        8
    hanxiV2EX  
       May 7, 2020 via Android   ❤️ 1
    就跟 c 语言的 goto 差不多,执行到某个地方 yield,函数就 return 了,再 resume 的时候又回到了上次 yield 的地方。只不过协程会帮你把函数堆栈都存好了,goto 回来的时候能继续找到上下文。
    ica10888
        9
    ica10888  
       May 7, 2020 via Android   ❤️ 2
    我想说 callcc,怕直接绕晕了...
    129tyc
        10
    129tyc  
       May 7, 2020 via Android   ❤️ 1
    协程的挂起可以通过 yield 主动放弃对 cpu 的占有,恢复则是由其他协程或调度器主动将其 resume,delay 只是挂起和恢复的组合,功能和效果上和线程的 delay 类似
    Cabana
        11
    Cabana  
       May 7, 2020 via Android   ❤️ 1
    jvm 的 kotlin 协程只是对线程调度的封装而已
    jswh
        12
    jswh  
       May 7, 2020   ❤️ 1
    传统意义上的协程是基于生成器的,可以在函数执行中间主动让出 cpu 占用,在下次调用的时候恢复函数上下文从中断的地方恢复执行,常见的语法就是 yield 。生成器语法只是提供了主动让出 cpu 占用的能力,要做到实用的协程一般还要搭配一个调度器,golang 语言自带,php 的 swoole,python tornado 等。同时所有相关库( io,网络等)都要用生成器形式来写在等待的时候让出 cpu,不然也没啥异步能力。
    itskingname
        13
    itskingname  
       May 7, 2020   ❤️ 2
    如果你看得懂 Python,我写了一篇 Python 相关的: https://mp.weixin.qq.com/s/spayiLNuTnFVOWWeW-jkwQ
    vk42
        14
    vk42  
       May 7, 2020   ❤️ 1
    @winterbells
    挂起恢复都是具体语言实现细节,你要看你所指的语言特性了。比如汇编可以用 long jump 来实现,c 可以用 goto 实现等等……
    wysnylc
        15
    wysnylc  
       May 7, 2020   ❤️ 1
    协程相关:
    [Kotlin 协程真的比 Java 线程更高效吗?]( https://cloud.tencent.com/developer/article/1570462)
    [为什么 Java 坚持多线程不选择协程?]( https://www.zhihu.com/question/332042250)
    Mrag
        16
    Mrag  
       Nov 26, 2020
    与事件驱动的机制很相似
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   2518 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 60ms · UTC 16:00 · PVG 00:00 · LAX 09:00 · JFK 12:00
    ♥ Do have faith in what you're doing.