进程(process)
进程理论基础
- 定义:程序在计算机中的一次运行。
- 程序是一个可执行的文件,是静态的占有磁盘
- 进程是一个动态的过程描述,占有计算机运行资源,有一定的生命周期
- 系统中如何产生一个进程
- 用户空间通过调用程序接口或者命令,发起请求
- 操作系统接收用户请求,开始创建进程
- 操作系统调配计算机资源,确定进程状态等
- 操作系统将创建的进程提供给用户使用
- 进程基本概念
- CPU时间片:如果一个进程占有CPU内核,则称这个进程在CPU时间片上。
- PCB(进程控制块):在内存中开辟的一块空间,用于存放进程的基本信息,也用于系统查找识别进程。
- 进程ID:系统为每个进程分配的一个大于0的整数,作为进程ID。每个进程ID不重复。
- Linux查看进程ID:ps -aux
- 父子进程:系统中每一个进程(除了系统初始化进程)都有唯一的父进程,可以有0个或多个子进程。父进程关系便于进程管理。
- 查看进程树:pstree
- 进程状态:
- 三态:
- 就绪态:进程具备执行条件,等待分配CPU资源
- 运行态:进程占有CPU时间片,正在运行
- 等待态:进程暂时停止运行,让出CPU
- 状态查看命令:ps -aux (STAT这一列)
- S:等待态
- R:执行态
- D:等待态
- T:等待态
- Z:僵尸
- <:较高优先级
- N:优先级较低
- +:前台进程
- s:会话组组长
- l:有多线程的
- 进程的运行特征:
- 进程可以使用计算机多核资源;
- 进程是计算机分配资源的最小单位;
- 进程之间的运行互不影响,各自独立;
- 每个进程拥有独立的空间,各自使用自己空间资源;
- fork:详见 多任务编程 -- 基于fork的多进程编程
- 进程相关函数:多任务编程 -- 进程相关函数 os.getpid()、os.getppid()、os._exit()、sys.exit()
- 孤儿和僵尸进程:多任务编程 -- 孤儿进程和僵尸进程
posted @
2020-05-16 22:38
Be-myself
阅读(
191)
评论()
编辑
收藏
举报
levels of contents
点击查看具体代码内容