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

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

一、进程

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索引方式

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


相关文章
|
4天前
|
分布式计算 JavaScript 前端开发
多线程、多进程、协程的概念、区别与联系
多线程、多进程、协程的概念、区别与联系
16 1
|
2天前
|
存储 负载均衡 算法
深入理解操作系统的进程调度
【6月更文挑战第20天】本文将探讨操作系统中的进程调度,包括其定义、重要性以及常见的调度算法。我们将通过具体的例子和代码片段来深入理解进程调度的工作原理和实现方式。最后,我们将讨论进程调度在现代操作系统中的应用和挑战。
|
1天前
|
存储 调度 C++
【操作系统】进程与线程的区别及总结(非常非常重要,面试必考题,其它文章可以不看,但这篇文章最后的总结你必须要看,满满的全是干货......)
【操作系统】进程与线程的区别及总结(非常非常重要,面试必考题,其它文章可以不看,但这篇文章最后的总结你必须要看,满满的全是干货......)
22 1
|
3天前
|
调度
操作系统之进程调度机制
操作系统之进程调度机制
8 1
|
4天前
|
存储 缓存 运维
深入理解操作系统:从进程管理到内存分配
在数字时代的心脏,操作系统扮演着至关重要的角色。本文将深入探讨操作系统的核心机制,包括进程管理、内存分配和文件系统,揭示它们如何协同工作以支持现代计算需求。通过技术深度解析和实际应用示例,我们将一窥操作系统的复杂性与优雅,理解其在软件开发和系统性能优化中的重要性。
|
5天前
|
负载均衡 算法 调度
深入理解操作系统之进程调度
本文旨在探究操作系统核心机制之一——进程调度。文章首先概述进程与线程的基本概念,随后详细解析进程调度的目标、常见算法及其优缺点,并探讨现代操作系统中进程调度的高级话题,如多核调度和实时系统的调度策略。通过实例分析,本篇文章将帮助读者深化对进程调度复杂性的理解,并指出未来可能的发展方向。
|
1天前
|
网络协议 Unix
每天3分钟操作系统修炼秘籍(17):进程间通信(3):套接字
每天3分钟操作系统修炼秘籍(17):进程间通信(3):套接字
|
18天前
|
存储 Linux 数据处理
探索Linux操作系统的内核与文件系统
本文深入探讨了Linux操作系统的核心组件,包括其独特的内核结构和灵活的文件系统。文章首先概述了Linux内核的主要功能和架构,接着详细分析了文件系统的工作原理以及它如何支持数据存储和检索。通过比较不同的文件系统类型,本文旨在为读者提供一个关于如何根据特定需求选择合适文件系统的参考框架。
|
8天前
|
存储 缓存 安全
Linux基础——冯诺依曼体系结构与操作系统
Linux基础——冯诺依曼体系结构与操作系统
34 1
Linux基础——冯诺依曼体系结构与操作系统
|
4天前
|
Linux 网络安全 虚拟化
Linux操作系统第一章(Linux操作系统的带入,vmware-17虚拟化软件运用,FinalShell远程连接Linux )
Linux操作系统第一章(Linux操作系统的带入,vmware-17虚拟化软件运用,FinalShell远程连接Linux )