Golang GMP模型

GM模型

 

第一个M怎么来的?,G怎么找到对应的P?

1. 系统启动的时候,首先跑的是主线程,那第一个M应该就是主线程吧M1

2. 然后这个主线程会绑定第一个P1

3. 咱们写的main函数,其实是作为一个goroutine来执行的(雨痕说的)

4. 也就是第一个P1就有了一个G1任务,然后第一个M1就执行这个G1任务(也就是main函数),创建这个G1的时候不用创建M了,因为已经有了M1

5. 这个main函数里面所有的goroutine,都绑定到当前的M1所对应的P1上

6. 然后创建main里的goroutine的时候(比如G2),就会创建新的M2,新的M2里的初始P2的本地任务队列是空的,会从P1里面取一些过来

7. 这样两个M1,M2各自执行自己的G任务,再依次往复

 

https://mp.weixin.qq.com/s/uWP2X6iFu7BtwjIv5H55vw

 

https://mp.weixin.qq.com/s/an7dml9NLOhqOZjEGLdEEw

posted @   林锅  阅读(108)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 25岁的心里话
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示