进程的状态
来源:互联网 发布:奶茶店销售额大数据 编辑:程序博客网 时间:2024/06/11 22:54
三态模型:在多道程序系统中,进程在处理器上交替运行,状态也不断地发生变化。进程一般有3种基本状态:运行、就绪和阻塞。
(1)运行:当一个进程在处理机上运行时,则称该进程处于运行状态。处于此状态的进程的数目小于等于处理器的数目,对于单处理机系统,处于运行状态的进程只有一个。在没有其他进程可以执行时(如所有进程都在阻塞状态),通常会自动执行系统的空闲进程。
(2)就绪:当一个进程获得了除处理机以外的一切所需资源,一旦得到处理机即可运行,则称此进程处于就绪状态。就绪进程可以按多个优先级来划分队列。例如,当一个进程由于时间片用完而进入就绪状态时,排入低优先级队列;当进程由I/O操作完成而进入就绪状态时,排入高优先级队列。
(3)阻塞:也称为等待或睡眠状态,一个进程正在等待某一事件发生(例如请求I/O而等待I/O完成等)而暂时停止运行,这时即使把处理机分配给进程也无法运行,故称该进程处于阻塞状态。
状态的转换
a) 就绪状态->执行状态:进程调度;
b) 执行状态->活动就绪状态:CPU时间片用完;
c) 执行状态->活动阻塞状态:等待时间(输入输出等操作);
d) 活动阻塞状态->活动就绪状态:时间发生(输入输出等操作完成);
e) 创建状态->活动就绪状态:创建之后接纳该进程;
f) 执行状态->终止状态:完成了该进程;
g) 活动阻塞状态->挂起阻塞状态:挂起命令;
h) 挂起阻塞状态->活动阻塞状态:激活命令;
i) 活动就绪状态->挂起就绪状态:挂起命令;
j) 挂起就绪状态->活动就绪状态:激活命令;
k) 执行状态->挂起就绪:挂起命令。
五态模型:对于一个实际的系统,进程的状态及其转换更为复杂。引入新建态和终止态构成了进程的五态模型。
新建态: 对应于进程刚刚被创建时没有被提交的状态,并等待系统完成创建进程的所有必要信息。 进程正在创建过程中,还不能运行。操作系统在创建状态要进行的工作包括分配和建立进程控制块表项、建立资源表格(如打开文件表)并分配资源、加载程序并建立地址空间表等。创建进程时分为两个阶段,第一个阶段为一个新进程创建必要的管理信息,第二个阶段让该进程进入就绪状态。由于有了新建态,操作系统往往可以根据系统的性能和主存容量的限制推迟新建态进程的提交。
终止态:进程已结束运行,回收除进程控制块之外的其他资源,并让其他进程从进程控制块中收集有关信息(如记帐和将退出代码传递给父进程)。类似的,进程的终止也可分为两个阶段,第一个阶段等待操作系统进行善后处理,第二个阶段释放主存。
由于进程的不断创建,系统资源特别是主存资源已不能满足所有进程运行的要求。这时,就必须将某些进程挂起,放到磁盘对换区,暂时不参加调度,以平衡系统负载;进程挂起的原因可能是系统故障,或者是用户调试程序,也可能是需要检查问题。
活跃就绪:是指进程在主存并且可被调度的状态。
静止就绪(挂起就绪):是指进程被对换到辅存时的就绪状态,是不能被直接调度的状态,只有当主存中没有活跃就绪态进程,或者是挂起就绪态进程具有更高的优先级,系统将把挂起就绪态进程调回主存并转换为活跃就绪。
活跃阻塞:是指进程已在主存,一旦等待的事件产生便进入活跃就绪状态。
静止阻塞:是指进程对换到辅存时的阻塞状态,一旦等待的事件产生便进入静止就绪状态。
0 0
- 进程的状态
- 进程的状态
- 进程的状态转换
- 进程的基本状态
- 进程的状态转换
- 进程的状态转换
- linux进程的状态
- 进程的状态转换
- 进程的状态转换
- 进程的状态转换
- 进程的状态转换
- 进程的状态
- 进程的状态转换
- 进程的状态
- 进程的状态转换
- 进程的状态模式
- 进程的状态
- 进程的状态
- 酒店管理系统_01_Servlet版本-项目搭建(引入Bootstrap)
- opencv学习(5)——腐蚀与膨胀
- MyBatis使用动态SQL语句
- 干货:MySQL 索引原理及慢查询优化
- 文章标题
- 进程的状态
- php中curl的使用
- CODE[VS] 1670 无穷的序列 简单数论
- strcpy
- linux下线程的分离状态和结合状态
- 50道编程小题目之【水仙花数】
- 系统内存不足,安装软件失败
- HTML5+规范:Downloader(管理网络文件下载任务)
- 分布式系统(三)——分布式共享内存和顺序一致性