进程是操作系统的资源分配和独立运行的基本单位。它一般由以下三个部分组成。
###进程控制块
进程创建时,操作系统就新建一个PCB结构,它之后就常驻内存,任一时刻可以存取, 在进程结束时删除。PCB是进程实体的一部分,是进程存在的唯一标志。
当创建一个进程时,系统为该进程建立一个PCB;当进程执行时,系统通过其PCB 了 解进程的现行状态信息,以便对其进行控制和管理;当进程结束时,系统收回其PCB,该进 程随之消亡。操作系统通过PCB表来管理和控制进程。
表2-1 PCB通常包含的内容
![](https://box.kancloud.cn/2016-02-16_56c29fbf46912.png)
表2-1是一个PCB的实例,PCB主要包括进程描述信息、进程控制和管理信息、资源 分配清单和处理机相关信息等。各部分的主要说明如下:
1) 进程描述信息
进程标识符:标志各个进程,每个进程都有一个并且是唯一的标识号。
用户标识符:进程归属的用户,用户标识符主要为共享和保护服务。
2) 进程控制和管理信息
进程当前状态:描述进程的状态信息,作为处理机分配调度的依据。
进程优先级:描述进程抢占处理机的优先级,优先级高的进程可以优先获得处理机。
3) 资源分配清单,用于说明有关内存地址空间或虚拟地址空间的状况;所打开文件的 列表和所使用的输入/输出设备信息。
4) 处理机相关信息,主要指处理机中各寄存器值,当进程被切换时,处理机状态信息 都必须保存在相应的PCB中,以便在该进程重新执行时,能再从断点继续执行。
在一个系统中,通常存在着许多进程,有的处于就绪状态,有的处于阻塞状态,而且阻塞的原因各不相同。为了方便进程的调度和管理,需要将各进程的PCB用适当的方法组织起来。目前,常用的组织方式有链接方式和索引方式两种。链接方式将同一状态的PCB链接成一个队列,不同状态对应不同的队列,也可以把处于阻塞状态的进程的PCB,根据其阻塞原因的不同,排成多个阻塞队列。索引方式是将同一状态的进程组织在一个索引表中,索引表的表项指向相应的PCB,不同状态对应不同的索引表,如就绪索引表和阻塞索引表等。
###程序段
程序段就是能被进程调度程序调度到CPU执行的程序代码段。注意,程序可以被多个进程共享,就是说多个进程可以运行同一个程序。
###数据段
一个进程的数据段,可以是进程对应的程序加工处理的原始数据,也可以是程序执行时产生的中间或最终结果。
- 1. 操作系统概述
- 2.操作系统(计算机)进程和线程管理
- 2.1 进程的概念和特征
- 2.2 进程的状态与转换
- 2.3 进程控制
- 2.4 进程的组
- 2.5 进程的通信
- 2.6 线程的概念和多线程模型
- 2.7 处理机调度
- 2.8 操作系统典型调度算法
- 2.9 进程同步的基本概念
- 2.10 实现临界区互斥的基本方法
- 2.11 信号量
- 2.12 管程:管程的定义、组成及基本特性
- 2.13 经典进程同步问题1
- 2.14 经典进程同步问题2:读者-写者问题
- 2.15经典进程同步问题3:哲学家进餐问题
- 2.16 经典进程同步问题4:吸烟者问题
- 2.17 死锁的概念以及产生死锁的原因
- 2.18 关于进程和线程的知识点汇总