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

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

一、进程

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

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


相关文章
|
2月前
|
算法 Linux 调度
深入理解Linux操作系统的进程管理
本文旨在探讨Linux操作系统中的进程管理机制,包括进程的创建、执行、调度和终止等环节。通过对Linux内核中相关模块的分析,揭示其高效的进程管理策略,为开发者提供优化程序性能和资源利用率的参考。
109 1
|
1月前
|
监控 搜索推荐 开发工具
2025年1月9日更新Windows操作系统个人使用-禁用掉一下一些不必要的服务-关闭占用资源的进程-禁用服务提升系统运行速度-让电脑不再卡顿-优雅草央千澈-长期更新
2025年1月9日更新Windows操作系统个人使用-禁用掉一下一些不必要的服务-关闭占用资源的进程-禁用服务提升系统运行速度-让电脑不再卡顿-优雅草央千澈-长期更新
128 2
2025年1月9日更新Windows操作系统个人使用-禁用掉一下一些不必要的服务-关闭占用资源的进程-禁用服务提升系统运行速度-让电脑不再卡顿-优雅草央千澈-长期更新
|
1月前
|
编解码 自然语言处理 JavaScript
智谱发布GLM-OS概念及Agent产品,CogAgent-9B模型开源助力GUI交互场景
11月29日,智谱正式提出 GLM-OS 概念,并发布 AutoGLM 和 GLM-PC 两款 Agent 产品。近期GLM-PC 的基座模型—— CogAgent-9B 开源,供社区进一步开发。
|
2月前
|
C语言 开发者 内存技术
探索操作系统核心:从进程管理到内存分配
本文将深入探讨操作系统的两大核心功能——进程管理和内存分配。通过直观的代码示例,我们将了解如何在操作系统中实现这些基本功能,以及它们如何影响系统性能和稳定性。文章旨在为读者提供一个清晰的操作系统内部工作机制视角,同时强调理解和掌握这些概念对于任何软件开发人员的重要性。
|
2月前
|
Linux 调度 C语言
深入理解操作系统:从进程管理到内存优化
本文旨在为读者提供一次深入浅出的操作系统之旅,从进程管理的基本概念出发,逐步探索到内存管理的高级技巧。我们将通过实际代码示例,揭示操作系统如何高效地调度和优化资源,确保系统稳定运行。无论你是初学者还是有一定基础的开发者,这篇文章都将为你打开一扇了解操作系统深层工作原理的大门。
|
2月前
|
存储 算法 调度
深入理解操作系统:进程调度的奥秘
在数字世界的心脏跳动着的是操作系统,它如同一个无形的指挥官,协调着每一个程序和进程。本文将揭开操作系统中进程调度的神秘面纱,带你领略时间片轮转、优先级调度等策略背后的智慧。从理论到实践,我们将一起探索如何通过代码示例来模拟简单的进程调度,从而更深刻地理解这一核心机制。准备好跟随我的步伐,一起走进操作系统的世界吧!
|
2月前
|
算法 调度 开发者
深入理解操作系统:进程与线程的管理
在数字世界的复杂编织中,操作系统如同一位精明的指挥家,协调着每一个音符的奏响。本篇文章将带领读者穿越操作系统的幕后,探索进程与线程管理的奥秘。从进程的诞生到线程的舞蹈,我们将一起见证这场微观世界的华丽变奏。通过深入浅出的解释和生动的比喻,本文旨在揭示操作系统如何高效地处理多任务,确保系统的稳定性和效率。让我们一起跟随代码的步伐,走进操作系统的内心世界。
|
2月前
|
运维 监控 Linux
Linux操作系统的守护进程与服务管理深度剖析####
本文作为一篇技术性文章,旨在深入探讨Linux操作系统中守护进程与服务管理的机制、工具及实践策略。不同于传统的摘要概述,本文将以“守护进程的生命周期”为核心线索,串联起Linux服务管理的各个方面,从守护进程的定义与特性出发,逐步深入到Systemd的工作原理、服务单元文件编写、服务状态管理以及故障排查技巧,为读者呈现一幅Linux服务管理的全景图。 ####
|
4天前
|
运维 自然语言处理 Ubuntu
OS Copilot-操作系统智能助手-Linux新手小白的福音
OS Copilot 是阿里云推出的一款操作系统智能助手,专为Linux新手设计,支持自然语言问答、辅助命令执行和系统运维调优等功能。通过简单的命令行操作,用户可以快速获取所需信息并执行任务,极大提升了Linux系统的使用效率。安装步骤简单,只需在阿里云服务器上运行几条命令即可完成部署。使用过程中,OS Copilot不仅能帮助查找命令,还能处理文件和复杂场景,显著节省了查找资料的时间。体验中发现,部分输出格式和偶尔出现的英文提示有待优化,但整体非常实用,特别适合Linux初学者。
43 10
|
3月前
|
安全 Linux 数据安全/隐私保护
Vanilla OS:下一代安全 Linux 发行版
【10月更文挑战第30天】
114 0
Vanilla OS:下一代安全 Linux 发行版

热门文章

最新文章