Go高级看这一篇就够了

引言

这部分需要把go的runtime弄明白

走完进阶后的一个最大感受是能把调度做好很难,跟现实中高级工程师一样,站在工程的角度看待设计、处理问题和调度资源。
这里只是搬过来,详细的描述请移步到他们的公众号或者博客,谢谢。
【go程序是怎么跑起来的】
【饶神公众号关于调度的十个系列】

第一、调度-GPM

1.reuse threads;
2.限制同时运行(不包含阻塞)的线程数为 N,N 等于 CPU 的核心数目;
3.线程私有的 runqueues,并且可以从其他线程 stealing goroutine 来运行,线程阻塞后,可以将 runqueues 传递给其他线程。

核心内容主要包括:

1、GPM 的初始化

在这里插入图片描述

2、M 是怎样一步步找工作
3、用户栈和 g0 栈的切换

在这里插入图片描述

4、schedule 的调度循环是怎样运转的

在这里插入图片描述

5、监控线程( sysmon)做了什么
  • 抢占处于系统调用的 P,让其他 m 接管它,以运行其他的 goroutine。

  • 将运行时间过长的 goroutine 调度出去,给其他 goroutine 运行的机会。

6、宏观状态转换
  • G:
    在这里插入图片描述
  • P:
    在这里插入图片描述
  • M:
    在这里插入图片描述

第二、go的GC

第三、go的内存管理

引用

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值