【GMP】写下go func的时候,到底发生了什么?

本文介绍了Go语言中的GMP模型,详细解析了G(goroutine)、M(machine,系统线程)和P(processor,虚拟处理器)的概念。阐述了G的生成流程,包括runnext、local run queue和global run queue的使用策略。此外,还详细说明了G的消费流程,涉及调度策略和work stealing机制。通过对Go调度机制的理解,有助于深入掌握Go并发的底层原理。
摘要由CSDN通过智能技术生成

背景

原理

我们先理解什么是G、M、P

G∶goroutine,一个计算任务。由需要执行的代码和其上下文组成,上下文包括∶当前代码位置,栈顶、栈底地址,状态等。


M∶ machine,系统线程,执行实体,想要在CPU上执行代码,必须有线程,与C语言中的线程相同,通过系统调用 clone 来创建。


P:processor,虚拟处理器,M必须获得P才能执行代码,否则必须陷入休
眠(后台监控线程除外),你也可以将其理解为一种 token,有这个 token,才有在物理 CPU核心上执行的权力。

Go的调度流程本质上是一个生产-消费流程

如上图所示,当我写一个go func的时候就好像我们在往队列里添加了一条数据 

P会有一个三级队列

第一级是runext

第二级是local run queue

第三级是global run queue(全局队列)

 这些队列就是用来存储我们写一次go func的时候就会生成一个G

那这些G的生成顺序和消费顺序是怎么样的?

一个新的G进来,它是如何存放的呢?

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值