进程的定义
一个具有一定独立功能的程序在一个数据集合上的一次动态执行过程。
进程的组成
进程包含了正在运行的一个程序的所有状态信息
- 程序的代码;
- 程序处理的数据;
- 程序计数器中的值,指示下一条将运行的指令;
- 一组通用的寄存器的当前值,堆、栈;
- (如打开的文件);
进程与程序的联系
- 程序是产生进程的基础
- 程序的每次运行构成不同的进程 进程是程序功能的体现
- 通过多次执行,一个程序可对应多个进程;
- 通过调用关系,一个进程可包括多个程序
进程和程序的区别
进程是动态的,程序是静态的
程序是有序代码的集合;进程是程序的执行,进程有核心态/用户态进程是暂时的,程序是永久的
进程是一个状态变化的过程,程序可长久保存进程与程序的组成不同
进程的组成包括程序、数据和进程控制块(即进程状态信息)
进程的特点
动态性
:可动态地创建、结束进程并发性
:进程可以被独立调度并占用处理机运行独立性
:不同进程的工作不相互影响制约性
:因访问共享数据/资源或进程间同步而产生制约
进程控制块结构
进程控制块:操作系统管理控制进程运行所用的信息集合
操作系统用PCB来描述进程的基本情况以及运行变化的过程,PCB是进程存在的唯一标志
使用进程控制块
进程的创建
:为该进程生成一个PCB进程的终止
:回收它的PCB进程的组织管理
:通过PCB的组织管理来实现
PCB含有以下三大类信息
进程标识信息
如本进程的标识,本进程的产生者标识(父进程标识),用户标识处理机状态信息保存区。
用户可见寄存器,用户程序可以使用的数据、地址等寄存器
控制和状态寄存器,如程序计数器(PC)、程序状态字(PSW)
栈指针,过程调用/系统调用/中断处理/和返回时需要用它- 保存进程的运行现场信息
PCB的组织方式
链表
同一状态的进程其PCB成一链表,多个状态对应多个不同的链表
各状态的进程形成不同的链表:就绪链表、阻塞链表索引表
同一状态的进程归入一个index表(有index指向PCB),多个状态对应多个不同的index表
各状态的进程形成不同的索引表:就绪索引表、阻塞索引表
进程的生命周期管理
进程创建
系统初始化时
用户请求创建一个新进程
正在运行的进程执行了创建进程的系统调用进程运行
内核选择一个就绪的进程进程等待
进程只能自己阻塞自己,因为只有进程自身才能知道何时需要等待某种事件的发生进程唤醒
将该进程的PCB插入到就绪队列 且 进程只能被别的进程或操作系统唤醒进程结束
正常退出(自愿的)
错误退出(自愿的)
致命错误(强制性的)
被其他进程所杀(强制性的)
进程状态变化模型
基本状态
运行状态(Running)
当一个进程正在处理机上运行时就绪状态(Ready)
一个进程获得了除处理机之外的一切所需资源,一旦得到处理机即可运行等待状态
(又称阻塞状态 Blocked)
一个进程正在等待某一时间而暂停运行时。如等待某资源,等待输入/输出完成
基本过程(状态点)
创建状态(New)
一个进程正在被创建,还没被转到就绪状态之前的状态结束状态(Exit)
一个进程正在从系统中消失时的状态,这是因为进程结束或由于其他原因。
可能的状态变化如下
- Null -> New:一个新进程被产生出来执行一个程序
- New -> Ready:当进程被创建完成并初始化后,一切就绪准备运行时,变为就绪状态(时间很短)
- Ready -> Running:处于就绪状态的进程被进程调度程序选中后,就分配到处理机上来运行
- Running -> Ready:处于运行状态的进程在其运行过程中,由于分配给它的处理机时间片用完而让出处理机(操作系统完成)
- Running -> Blocked:当进程请求某样东西且必须等待时
Blocked -> Ready:当进程要等待某事件到来时,它从阻塞状态变到就绪状态
进程挂起
进程没有占用内存空间。处在挂起状态的进程映像在外存中
挂起状态
阻塞挂起状态(Blocked-suspend)
进程在外存并等待某事件的出现就绪挂起状态(Ready-suspend)
进程在外存,但只要进入内存,即可运行;
状态转换
挂起(suspend):内存→外存
- 阻塞到阻塞挂起: 没有进程处于就绪状态或就绪状态进程要求更多内存资源时,会进行这种转换,以提交新进程或运行就绪进程。
- 就绪到就绪挂起:当有高优先级阻塞(系统认为很快就绪的)进程和低优先级就绪进程时,系统会选择挂起低优先级就绪进程。
- 运行到就绪挂起:对抢先式分时系统,当有高优先级阻塞挂起进程因事件出现而进入就绪挂起时,系统可能会把运行进程转到就绪挂起状态。
转换后仍在外存
- 阻塞挂起到就绪挂起:当有阻塞挂起进程因相关事件出现时,系统会把阻塞挂起进程转换为就绪挂起进程。
解挂/激活(Activate):外存→内存
- 就绪挂起到就绪:没有就绪进程或挂起就绪进程优先级高于就绪进程时,会进行这种转换。
- 阻塞挂起到阻塞:当一个进程释放足够多内存时,系统会把一个高优先级阻塞挂起(系统认为会很快出现所等待的事件)进程转换为阻塞进程。
状态队列
- 由操作系统来维护一组队列,用来表示系统当中所有进程的当前状态;
- 不同的状态分别用不同的队列表示(就绪队列、各种类型的阻塞队列);
- 每个进程的PCB都根据它的状态加入到相应的队列当中,当一个进程的状态发生变化时,它的PCB从一个状态队列中脱离出来,加入到另外一个队列。