Linux内核设计与实现之读书笔记(一)

进程管理主要有:进程描述、进程创建、线程实现、进程终结。

进程描述

进程是资源分配的基本单位,进程由PCB、数据(资源)、程序组成,内核调用的是线程,每个线程都有唯一的一个计数器、进程栈、一组进程寄存器。内核通过一个双向链表管理进程,链表的每个节点为进程描述符,PCB包含进程打开的文件、进程的地址空间、进程的状态。

分配进程描述符:Linux通过slab分配task-struct结构,通过一个thread-info的数据结构的一个指针指向分配的task-struct。

进程描述符的识别:每个进程描述符都有一个PID,唯一标识进程。

进程状态:进程描述符中有一个字段state描述进程的状态,进程的状态分为五种:task-running、task-interruptable、task-traced、task-stop、task-uninterruptable。

进程上下文:当用户程序调用了内核时,用户程序陷入内核,处于进程上下文。

进程家族树:Linux进程有严格的继承关系,每个其他进程都为init进程的子进程,init在内核启动最后加载进入内存,该进程初始化脚本,并执行相应的程序,完成系统初始化。


进程创建:

Linux中进程的主要通过fork()、exec()完成创建,一般的fork()拷贝一个和父进程一样资源的子进程(进程标识符区别),Linux中fork()使用写时拷贝,父进程和子进程共用同一个资源拷贝,在执行子进程时,才将需要的数据复制进入内存。

线程创建:

线程机制使得线程能在同一个进程中共享内存空间,并且可以一定程度上共享资源,从而实现concurrent programming 。轻量级进程是其他系统所有的,其他系统共享资源常常是在一个进程中新建四个线程共享资源,在Linux中线程常常被看成进程,分配PCB,在共享资源时,常常通过指针指向同一个资源。

进程终结:

进程终结后需要释放进程所占用的资源,删除进程描述符,在程序执行完main函数后,c编译器会自动调用exit()函数,当父进程执行完后,其对应的子进程在相应的线程组内会找到父进程,否者init作为其父进程。

你可能感兴趣的:(Linux内核设计与实现之读书笔记(一))