【操作系统】进程的基本概念&进程的状态与转换&进程的组织方式


在这里插入图片描述

🐌个人主页: 🐌 叶落闲庭
💨我的专栏:💨
c语言
数据结构
javaEE
操作系统

石可破也,而不可夺坚;丹可磨也,而不可夺赤。


一、进程

1.1概念

  • 程序:是静态的,就是个存放在磁盘里的可执行文件,就是一系列的指令集合
  • 进程:是动态的,是程序的一次执行过程(同一个程序多次执行会对应多个进程)

在这里插入图片描述


1.2组成

  • 当进程被创建时,操作系统会为该进程分配一个唯一的、不重复的“身份证号” – – PID(Process ID,进程ID)

在这里插入图片描述


  • 基本的进程描述信息,可以让操作系统区分各个进程:操作系统要记录PID、进程所属用户ID(UID)
  • 可用于实现操作系统对资源的管理:记录给进程分配了哪些资源(如:分配了多少内存、正在使用哪些I/O设备、正在使用哪些文件)
  • 用于实现操作系统对进程的控制、调度:记录进程的运行情况(如:CPU使用时间、磁盘使用情况、网络流量使用情况等)
  • 这些信息都被保存在一个数据结构PCB(Process Control Block)中,即进程控制块
  • 操作系统需要对各个并发运行的进程进行管理,但凡管理时所需要的信息,都会被放在PCB中
  • 处理机相关信息:如PSW、PC等各种寄存器的值(用于实现进程切换 )
  • 进程的组成:
  • PCB:
      • 进程描述信息
      • 进程控制和管理信息
      • 资源分配清单
      • 处理机相关信息
  • 程序段:
      • 程序的代码(指令序列)
  • 数据段
    • 运行过程中产生的各种数据(如:程序中定义的变量)
  • PCB是给操作系统用的
  • 程序段、数据段是给进程自己用的
  • 一个进程实体(进程映像)由PCB、程序段、数据段组成
  • 进程是动态的,进程实体(进程映像)是静态的
  • 进程实体反映了进程在某一时刻的状态(如:x++后,x=2)
  • 进程定义:
    • 进程是进程实体的运行过程,是系统进行资源分配和调度的一个独立单位(一个进程被“调度”,就是指操作系统决定让这个进程上CPU运行)
    • 注意:PCB是进程存在的唯一标志

1.3特征

  • 动态性:进程是程序的一次执行过程,是动态的产生、变化和消亡的(最基本的特征)
  • 并发性:内存中有多个进程实体,各进程可并发执行
  • 独立性:进程是能独立运行、独立获得资源、独立接收调度的基本单位
  • 异步性:各进程按各自独立的、不可预知的速度向前推进,操作系统要提供“进程同步机制”来解决异步问题
  • 结构性:每个进程都会配置一个PCB,结构上看,进程由程序段、数据段、PCB组成

二、进程的状态与转换


在这里插入图片描述


  • 进程正在被创建时,他的状态是“创建态”,在这个阶段操作系统会为进程分配资源、初始化PCB
  • 当进程创建完成后,便进入“就绪态”,处于就绪态的进程已经具备运行条件,但由于没有空闲CPU,就暂时不能运行
  • 如果一个进程此时在CPU上运行,那么这个进程处于“运行态”,CPU会执行该进程对应的程序(执行指令序列)
  • 在进程运行的过程中,可能会请求等待某个事件的发生(如等待某种系统资源的分配,或者等待其他进程的响应)
  • 在这个时间发生之前,进程无法继续往下进行,此时操作系统会让这个进程下CPU,并让他进入“阻塞态”
  • 当CPU空闲时,又会选择另一个“就绪态”进程上CPU运行
  • 一个进程可以执行exit系统调用,请求操作系统终止该进程
  • 此时该进程会进入“终止态”,操作系统会让该进程下CPU,并回收内存空间等资源,最后还要回收该进程的PCB,当终止进程的工作完成后,这个进程就彻底消失了。

在这里插入图片描述


  • 运行态–>阻塞态是一种进程自身做出的主动行为
  • 阻塞态–>就绪态不是进程自身能控制的,是一种被动行为。
  • 注意:不能由阻塞态直接转换为运行态,也不能由就绪态直接转换为阻塞态(因为进入阻塞态是进程主动请求的,必然需要进程在运行时才能发出这种请求)

在这里插入图片描述


  • 运行态–>就绪态
    在这里插入图片描述

  • 进程PCB中会有一个变量state来表示进程的当前状态
  • 为了对同一个状态下的各个进程进行统一的管理,操作系统会将各个进程的PCB组织起来

三、进程的组织

3.1链式方式

  • 执行指针:指向当前处于运行态(执行态)的进程,单CPU中,同一时刻只会有一个进程处于运行态
  • 就绪队列指针:指向当前处于就绪态的进程,通常会把优先级高的进程放在队头
  • 阻塞队列指针:指向当前处于阻塞态的进程,很多操作系统还会根据阻塞原因不同,再分为多个阻塞队列

3.2索引方式

  • 根据进程状态的不同,建立几张索引表
  • 操作系统持有指向各个索引表的指针

在这里插入图片描述


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

叶落闲庭

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值