Go Goroutine运行切换
Goroutine称呼上一般被我们理解为协程(Coroutine),类似于轻量级“线程”。
- Goroutine是一种编译器/解释器/虚拟机层面的多任务,并不属于操作系统。
- 多个协程可能在一个或多个线程上运行(由调度器决定)
对比操作系统(*nix)的进程或线程来说,Goroutine作为非抢占式多任务处理,由协程主动交出控制权,也就是说,要么协程自动运行完毕,或者调度器主动来进行切换,否则,协程不会主动交出运行控制的。
什么情况下,调度器会参与呢?
- I/O操作,类似于阻塞的系统的调用(异步唤醒)。
- select Channel
- 等待锁
- 函数调用
- Runtime.Gosched()
- 其他地方也有可能会切换
总的来说,当Goroutine不能继续向下执行时,需要等待时,调度器都有可能参与调度(根据以上状况和查Google得出,未结合源码进行分析验证)。
更新,更为详细的介绍,附加一篇博客:6.7 协作与抢占。
本文标题:Go Goroutine运行切换
文章作者:小师
发布时间:2018-08-19
最后更新:2022-05-04
原始链接:chunlife.top/2018/08/19/Go-Goroutine运行切换/
版权声明:本站所有文章均采用知识共享署名4.0国际许可协议进行许可