go语言调度器源代码情景分析之一:开篇语
专题简介
本专题以精心设计的情景为线索,结合go语言最新1.12版源代码深入细致的分析了goroutine调度器实现原理。
适宜读者
- go语言开发人员
- 对线程调度器工作原理感兴趣的工程师
- 对计算机底层运行原理感兴趣的工程师
专题目标
笔者希望即使是从未接触过计算机底层原理的读者,通过对本专栏的认真学习,都可以完全掌握go语言调度器的实现原理及细节,从而可以充分利用go调度器的特性写出更加优秀的并发程序和解决一些与调度相关的疑难杂症;另外,读者还可以学到大量与程序运行相关的基础知识,比如汇编代码,CPU如何执行指令以及并发无锁编程等等非常重要的编程内功心法,有了这些基础理论,在今后的学习和工作中,读者就完全有能力对其它一些自己感兴趣的底层实现原理做深入的分析。
如何学习本专栏
编程是一门实践性很强的技术,所以建议读者在阅读本专栏时多注重实践练习,特别是在学习第一部分的汇编指令及函数调用栈等知识的时候,读者可以自己写一些小程序然后用调试工具单步执行来跟踪寄存器以及栈的变化,从而更好的理解这些内容。
专栏模块
本专栏主要分为两大部分:
- 第一部分包括第一章,主要介绍理解调度器工作原理所必须的预备知识,比如汇编指令,函数调用过程,操作系统线程调度原理以及线程本地存储等重要理论知识。这部分内容主要是为从未接触过底层知识的读者准备的,如果读者对这部分已经很熟了,则完全可以跳过这部分的阅读。
- 第二部分包括第2到第6章,主要分析goroutine调度器的实现,包括调度器的初始化,调度策略以及主动被动和抢占调度等,在分析过程中我们不仅会介绍调度器在干什么,更重要的是我们还会详细说明为什么要这么做,让读者知其然也知其所以然。
专栏章节(初稿已经全部完成,逐渐放上来)
开篇语
第一章 预备知识
1. CPU寄存器
2. 内存
3. 函数调用栈
4. 汇编指令
5. go语言汇编
6. 函数调用过程
7. 系统调用
8. 操作系统线程及调度
9. 线程本地存储
第二章 初始化和调度循环
1. 调度器概述
2. 程序启动和调度器初始化
3. 创建main goroutine
4. 启动main goroutine
第三章 调度策略
1. goroutine的退出与调度循环
2. 再探schedule函数与寻找可运行的goroutine
3. 盗取goroutine与工作线程睡眠
第四章 被动调度
1. goroutine进入运行队列
2. goroutine进入睡眠
3. 唤醒睡眠中的goroutine与工作线程
4. 创建工作线程
第五章 主动调度
1. 主动调度
第六章 抢占调度
1. 抢占运行时间过长的goroutine
2. goroutine进入系统调用以及从系统调用返回
3. 抢占进入系统调用的goroutine
作者简介
爱写程序的阿波张,男,程序员,高级技术专家。
15年软件开发经验,做过应用层软件,也玩过操作系统内核,目前专注于K12在线教育创业中。
对计算机底层运行原理很感兴趣,熟悉X86汇编/C/C++/Go。
最后,欢迎关注个人微信公众号:go语言核心编程技术
go语言调度器源代码情景分析之一:开篇语的更多相关文章
- go语言调度器源代码情景分析之五:汇编指令
本文是<go调度器源代码情景分析>系列 第一章 预备知识的第4小节. 汇编语言是每位后端程序员都应该掌握的一门语言,因为学会了汇编语言,不管是对我们调试程序还是研究与理解计算机底层的一些运 ...
- go语言调度器源代码情景分析之四:函数调用栈
本文是<go调度器源代码情景分析>系列 第一章 预备知识的第3小节. 什么是栈 栈是一种“后进先出”的数据结构,它相当于一个容器,当需要往容器里面添加元素时只能放在最上面的一个元素之上,需 ...
- go语言调度器源代码情景分析之三:内存
本文是<go调度器源代码情景分析>系列 第一章 预备知识的第2小节. 内存是计算机系统的存储设备,其主要作用是协助CPU在执行程序时存储数据和指令. 内存由大量内存单元组成,内存单元大小为 ...
- go语言调度器源代码情景分析之二:CPU寄存器
本文是<go调度器源代码情景分析>系列 第一章 预备知识的第1小节. 寄存器是CPU内部的存储单元,用于存放从内存读取而来的数据(包括指令)和CPU运算的中间结果,之所以要使用寄存器来临时 ...
- go语言调度器源代码情景分析之六:go汇编语言
go语言runtime(包括调度器)源代码中有部分代码是用汇编语言编写的,不过这些汇编代码并非针对特定体系结构的汇编代码,而是go语言引入的一种伪汇编,它同样也需要经过汇编器转换成机器指令才能被CPU ...
- 《Android系统源代码情景分析》连载回忆录:灵感之源
上个月,在花了一年半时间之后,写了55篇文章,分析完成了Chromium在Android上的实现,以及Android基于Chromium实现的WebView.学到了很多东西,不过也挺累的,平均不到两个 ...
- linux调度器源码分析 - 初始化(二)
本文为原创,转载请注明:http://www.cnblogs.com/tolimit/ 引言 上期文章linux调度器源码分析 - 概述(一)已经把调度器相关的数据结构介绍了一遍,本篇着重通过代码说明 ...
- [翻译] 深入浅出Go语言调度器:第一部分 - 系统调度器
目录 译者序 序 介绍 系统调度器 执行指令 Figure 1 Listing 1 Listing 2 Listing 3 线程状态 任务侧重 上下文切换 少即是多 寻找平衡 缓存行 Figure 2 ...
- Linux内核源代码情景分析系列
http://blog.sina.com.cn/s/blog_6b94d5680101vfqv.html Linux内核源代码情景分析---第五章 文件系统 5.1 概述 构成一个操作系统最重要的就 ...
随机推荐
- 3D Lut 电影级调色算法 附完整C代码
在前面的文章,我提到过VSCO Cam 的胶片滤镜算法实现是3d lut. 那么3d lut 到底是个什么东西呢? 或者说它是用来做什么的? 长话短说,3d lut(全称 : 3D Lookup t ...
- Python撸支付宝红包教程,行走在灰色产业边缘的程序员!
2018年刚到就作死撸羊毛(支付宝).2017年用分享给支付宝好友链接的官方通道"撸"了400大洋. 如许天天早上7:30便起床开愉快心的分享红包链接.200多个老友分享完一次 ...
- 压力测试工具ab - Apache HTTP server benchmarking tool
搞互联网开发,压力测试必不可少.压力测试的工具很多,我用过ab和JMeter,今天主要讲ab的用法. 1.ab是什么 ab is a tool for benchmarking your Apache ...
- 0516js综合练习
<!DOCTYPE html><html> <head> <meta charset="UTF-8"> ...
- java并发之TimeUnit理解
TimeUnit是java.util.concurrent包下面的一个类,TimeUnit提供了可读性更好的线程暂停操作,通常用来替换Thread.sleep(),在很长一段时间里Thread的sle ...
- js中点与方括号及for...in
中括号运算符总是能代替点运算符.但点运算符却不一定能全部代替中括号运算符. 当用中括号代替点时,属性名需加双引号. 中括号运算符可以用字符串变量的内容作为属性名.点运算符不能. 中括号运算符可以用纯数 ...
- 【数据结构】B-Tree, B+Tree, B*树介绍
[摘要] 最近在看Mysql的存储引擎中索引的优化,神马是索引,支持啥索引.全是浮云,目前Mysql的MyISAM和InnoDB都支持B-Tree索引,InnoDB还支持B+Tree索引,Memory ...
- HQL: The Hibernate Query Language
Chapter 14. HQL: The Hibernate Query Language 14.1. Case Sensitivity 14.2. The from clause 14.3. Ass ...
- python中用locust做简单的压力测试
验证导入包成功 首先导入locust模块,百度一下导入方法很多,就不多说了 验证导入成功或失败,在终端中(windows中是cmd)输入:locust --help 导入成功后会出现如下界面: 编辑运 ...
- 陌陌架构分享 – Apple Push Notification Service
http://blog.latermoon.com/?p=878 先描述下基本概念,标准的iPhone应用是没有后台运行的,要实现实时推送消息到手机,需要借助Apple提供的APNS服务. iPhon ...