Linux 内核结构组成之进程调度,java 开发直播系统相关教程
僵死态:进程已经被中止但它的状态还没有被父进程获取。
暂停态:处于暂停状态的进程,一般都是由执行态转换而来,等待某种特殊处理,比如处于调试跟踪的程序,每执行到一个断点就转入暂停态,等待新的信号输入。
三、Linux 进程的结构
Linux 中一个进程在内存中有 3 部分数据,分为数据段、堆栈段、代码段。
代码段:用来存放程序代码,如果有多个程序运行相同的一个程序,那么可以使用同一个代码段;
数据段:用来存放程序的全局变量、常数以及动态数据分配的数据空间;
堆栈段:用来存放子程序的返回地址、子程序的参数以及程序的局部变量。还包括进程控制块 PCB,PCB 处于进程的核心堆栈的底部,不需要额外分配空间。
可以看我的另一篇博客:代码段(codesegment/textsegment)、数据段(datasegment)、bss段(bsssegment)、rodata段、栈(stack)、堆(heap)
四、进程的种类
交互进程:有一个 shell 启动的进程,既可以在前台运行,也可以在后台运行;
批处理进程:不与特定的终端相关联,提交到等待队列中顺序执行进程;
守护进程:在 Linux 启动时初始化,需要时运行于后台的一些服务进程
五、进程的创建
使用 fork()函数创建进程,这个函数名是“分叉”的意思,具体使用格式如下
#include <sys/type.h> //提供类型 pid_t 的定义
#include <unistd.h> //提供函数的定义
pid_t for
k(); //创建进程
调用 fork()函数后,Linux 系统会赋值一个与父进程完全相同的子进程,这两个进程共享代码空间,但数据空间是相互独立的,子进程的数据空间中的内容是父进程的完整复制,指令指针也完全相同。唯一不同的是子进程 fork 的返回值是 0,父进程 fork 的返回值是子进程的进程号,如果 fork 不成功,父进程会返回错误。
六、 Linux 进程控制块 task_struct 的结构描述
Linux 在内核空间专门开辟了一个指针数组 task,用来有效的管理所有进程控制块 task_struct 结构的指针。Task 数组大小限制了系统并发执行的进程总数。task_struct 结构包含如下信息:
进程当前的状态;
调度信息:进程的类别、调度策略、优先级等调度属性;
进程标识:进程标识号 PID、组标识号 GID、用户标识 UID;
进程通信信息:Linux 支持多种通信机制,也存储在其中;
进程的家族关系:有许多进程指针,分别指向祖先进程(初始化进程)、父进程、子进程及新、老进程的 task_struct 结构;
时间和定时信息:用于追踪和记录进程的整个生存期内使用 CPU 的时间;
文件系统信息:保存了进程和文件系统的相关信息;
存储管理信息:存储了进程虚拟存储空间信息及其与物理内存相关的信息;
CPU 现场保留信息:CPU 寄存器、堆栈等环境
评论