黄志恒
原创作品转载请注明出处
《Linux内核分析》MOOC课程http://mooc.study.163.com/course/USTC-1000029000
这篇文章来分析Linux操作系统创建一个子进程的具体流程。本文设计的Linux操作系统基于Linux-3.18.6内核,实验环境又实验楼提供,地址:http://www.shiyanlou.com/courses/195。再次感谢孟老师的网上指导。
首先,要明白这样一个事情:在内核启动的时候会生成0号进程;之后0号进程创建1号进程和2号进程;再之后1号进程是所有用户态进程的祖先,2号进程是所有内核线程的祖先。也就是我们使用操作系统创建进程和线程的时候都不是原始的编写一个出来的,而是通过复制并修改父进程的结构得来的。
说起进程的结构就不得不提起PCB(进程控制块)。PCB是描述一个进程的数据块。在内核中对应task_struct代码。而子进程的PCB是复制并修改父进程的PCB得来的。那么就有必要看一看PCB也就是task_struct中到底定义了什么。这里得交代一下,task_struct结构体有400多行代码,结构复杂不易理解。这里我贴出一份博客,那里有详细的解释。请各位看官务必先阅读下这篇详解task_struct的博客http://blog.youkuaiyun.com/jnu_simba/article/details/11724277。我也一并贴出t