专题简介

    本专题以精心设计的情景为线索,结合 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语言调度器源代码情景分析之一:开篇语 - 爱写程序的阿波张 - 博客园 - 图1
    https://www.cnblogs.com/abozhang/p/10766628.html