写点什么

Linux 内核结构组成之进程调度,java 开发直播系统相关教程

作者:Java高工P7
  • 2021 年 11 月 10 日
  • 本文字数:1094 字

    阅读完需:约 4 分钟

  • 僵死态:进程已经被中止但它的状态还没有被父进程获取。

  • 暂停态:处于暂停状态的进程,一般都是由执行态转换而来,等待某种特殊处理,比如处于调试跟踪的程序,每执行到一个断点就转入暂停态,等待新的信号输入。


三、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


《Android学习笔记总结+最新移动架构视频+大厂安卓面试真题+项目实战源码讲义》
浏览器打开:qq.cn.hn/FTe 免费领取
复制代码


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 寄存器、堆栈等环境

用户头像

Java高工P7

关注

还未添加个人签名 2021.11.08 加入

还未添加个人简介

评论

发布
暂无评论
Linux内核结构组成之进程调度,java开发直播系统相关教程