Go语言中为什么要有GMP调度模型
学习知识要善于思考,思考,再思考!今天golang学习网小编就给大家带来《Go语言中为什么要有GMP调度模型》,以下内容主要包含go语言、gmp等知识点,如果你正在学习或准备学习Golang,就都不要错过本文啦~让我们一起来看看吧,能帮助到你就更好了!
今天小编给大家分享一下Go语言中为什么要有GMP调度模型的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。
GMP调度模型是Go的精髓所在,它合理地解决了多线程并发调度协程的效率问题。
GMP是什么
首先得清楚,GMP各代指什么东西。
G: Goroutine的缩写,指协程,运行在线程上。
M: Machine的缩写,即thead,线程,循环的调度协程并执行。
P: Processor的缩写,指处理器,将协程储存到本地队列,并为线程提供未休眠的可用的协程,
线程M各自持有一个处理器P,当要获取协程时优先从P中获取,于是GMP模型图解如下:

大致流程是,线程M从P的队列中获取协程,如果获取不到,就会从全局队列中去竞争锁来获取。
处理器P
协程G和线程M结构在前几篇已经讲解了,这里解析一下处理器P。
作用
处理器P储存着一批协程,使得线程M可以无锁的从中获取协程,而无需与其他线程去竞争全局队列中的协程,从而提高调度协程效率。
源码解析
p结构体源码在src\runtime\runtime2.go中,这里展示部分重要字段。
type p struct {
...
m muintptr // back-link to associated m (nil if idle)
// Queue of runnable goroutines. Accessed without lock.
runqhead uint32
runqtail uint32
runq [256]guintptr
runnext guintptr
...
}m为处理器p所属的线程runq是一个储存协程的队列runqhead,runqtail表示队列的头尾指针runnext指向下一个可运行的协程

线程M与处理器P是如何协作的?
在src\runtime\proc.go中,有一个schedule方法,这是线程运行的第一个函数。这函数中,线程需要获取到可运行的协程,代码如下:
func schedule() {
...
// 寻找一个可运行的协程
gp, inheritTime, tryWakeP := findRunnable()
...
}func findRunnable() (gp *g, inheritTime, tryWakeP bool) {
// 从本地队列中获取协程
if gp, inheritTime := runqget(pp); gp != nil {
return gp, inheritTime, false
}
// 本地队列拿不到则从全局队列中获取协程
if sched.runqsize != 0 {
lock(&sched.lock)
gp := globrunqget(pp, 0)
unlock(&sched.lock)
if gp != nil {
return gp, false, false
}
}
}从本地队列中获取协程
func runqget(pp *p) (gp *g, inheritTime bool) {
next := pp.runnext // 队列中下一个可运行的协程
if next != 0 && pp.runnext.cas(next, 0) {
return next.ptr(), true
}
...
}那如果本地队列和全局队列中都没有协程了怎么办呢,难道就让线程这么闲着?
这时候处理器P就会任务窃取,从其他线程的本地队列中窃取一些任务,美其名曰分担其他线程的压力,还提高了自己线程的利用率。
源码在src\runtime\proc.go\stealWork中,感兴趣可以看看。
新建的协程该分配到哪?
新建的协程该分配到本地还是全局队列呢,得分情况:
Go认为新协程的优先级高,于是先寻找本地队列放入,而且还插队。
本队队列满了才放入全局队列。
实际流程为:
随机寻找P
将新协程放入P的
runnext中,意味着下一个就运行该协程,插队了若P的协程满了,则放入全局队列
源码在src\runtime\proc.go\newproc函数中。
// Create a new g running fn.
// Put it on the queue of g's waiting to run.
// The compiler turns a go statement into a call to this.
func newproc(fn *funcval) {
gp := getg()
pc := getcallerpc()
systemstack(func() {
newg := newproc1(fn, gp, pc) // 创建新协程
pp := getg().m.p.ptr()
runqput(pp, newg, true) // 寻找本地队列放入
if mainStarted {
wakep()
}
})
}以上就是“Go语言中为什么要有GMP调度模型”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注golang学习网行业资讯频道。
文中关于golang的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《Go语言中为什么要有GMP调度模型》文章吧,也可关注golang学习网公众号了解相关技术文章。
人工智能之yolov7目标检测在ubuntu上部署
- 上一篇
- 人工智能之yolov7目标检测在ubuntu上部署
- 下一篇
- go语言中的create方法如何用
-
- Golang · Go教程 | 1天前 | singleflight · 并发控制 · Go教程 · 缓存治理 · 接口优化 · Go 并发请求 缓存击穿 singleflight 缓存回填
- Go singleflight 防缓存击穿实战:相同请求只查一次数据库
- 114浏览 收藏
-
- Golang · Go教程 | 3天前 | golang
- Go 线上故障复盘模板:日志、指标、链路追踪与 pprof 证据闭环
- 710浏览 收藏
-
- Golang · Go教程 | 3天前 | golang
- Go 微服务超时、重试与熔断观测:避免故障放大的实践
- 687浏览 收藏
-
- Golang · Go教程 | 3天前 | golang
- Go 错误处理与告警设计:errors 包装、日志字段与告警降噪
- 664浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 485次学习
-
- TRAE Work
- TRAE AI IDE | 国内首款 AI 原生集成开发环境,深度集成 Doubao-1.5-pro 与 DeepSeek 模型,支持中文自然语言一键生成完整代码框架,实时预览前端效果并智能修复 BUG。首创 Builder 模式实现需求到代码的自动化开发,兼容 Windows/macOS 系统,官网下载即用。
- 24次使用
-
- MeloLab
- MeloLab 是一款 AI 音乐生成工具,可根据文本创意生成歌曲、人声、混音、分轨和背景音乐,适合创作者快速制作音乐素材。
- 23次使用
-
- ChatExcel酷表
- ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
- 8670次使用
-
- Any绘本
- 探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
- 9083次使用
-
- 可赞AI
- 可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
- 8912次使用
-
- 有关Go语言拼接URL路径的方法
- 2023-03-09 185浏览
-
- go语言能不能做后端
- 2023-03-03 460浏览
-
- go语言和java的区别是什么
- 2023-03-03 430浏览
-
- go语言如何进行强制类型转换
- 2023-03-04 450浏览
-
- go语言的beego怎么使用
- 2023-03-03 320浏览

