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

you are the best!
原文地址:https://www.cnblogs.com/linguoguo/p/15449417.html