Go语言调度器(G-P-M模型)

本文深入探讨了Go语言的抢占式调度,包括基于协作和信号的抢占方式,并详细阐述了G-P-M模型,即Goroutine、Processor和Machine之间的交互。文章还介绍了调度器的启动运行过程、常见调度情况以及系统监控中的角色,强调了P在调度中的重要性,以确保Goroutine的公平执行和系统资源的有效利用。
摘要由CSDN通过智能技术生成

目录

Go抢占式调度

基于协作的抢占式调度

基于信号的抢占式调度

G-P-M

调度器启动运行过程

常见调度情况

主动挂起

系统调用

系统监控


参考及引用

  1. 掘金
  2. Go: Goroutine, 系统线程和CPU管理 – 陈思敏捷 (chenjie.info)
  3. Go: sysmon, 运行时监控 – 陈思敏捷 (chenjie.info)
  4. Go 语言调度器与 Goroutine 实现原理 | Go 语言设计与实现 (draveness.me)


目录

Go抢占式调度

基于协作的抢占式调度

基于信号的抢占式调度

G-P-M

调度器启动运行过程

常见调度情况

主动挂起

系统调用

系统监控

为什么需要P?


Go抢占式调度

详细请看引用4

基于协作的抢占式调度

它使得所有的goroutine在函数调用时都有机会进入运行时检查是否需要执行抢占,通过以下特性实现

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值