王道操作系统考研笔记——2.1.1 进程的定义、组成、组织方式和特征

如果这篇博客对您有用的话,可以给我点个赞吗,这对我很重要,谢谢!❤️

文章目录

      • 2.1.1 进程的定义、组成、组织方式和特征
        • 2.1.1.1 进程的定义
        • 2.1.1.2 进程的定义
        • 2.1.1.3 进程的组成
        • 2.1.1.4 进程的组织
        • 2.1.1.5 链接方式
        • 2.1.1.6 索引方式
        • 2.1.1.7 进程的特征
        • 2.1.1.8 小结

2.1.1 进程的定义、组成、组织方式和特征

知识总览

image-20220118104903265

2.1.1.1 进程的定义

在讲述进程之前,我们首先要了解一个概念:程序

程序实际上就是一个指令序列;早期的计算机那时候只支持单道程序,也就是说,在一个程序传入内存的时候,CPU供他使用,内存供他使用,I/O设备也供他使用。

image-20220118105356960

在这个阶段中,内存属于某一个程序。内存中存放的东西分为两类:一种是程序段,一种是数据段;程序段就是这个程序的代码,而程序里所包含的数据就处于数据段内(如变量、常量)。


引入多道程序技术后;同一时刻内内存中可以放入多道程序,各个程序中的代码、运算程序存放的位置不同。操作系统如果想要在内存中找到各程序的存放位置,那就需要引进进程的概念了。

为了方便操作系统管理,完成各程序并发执行,人们引入了进程、进程实体的概念。系统为每个运行的程序配置一个数据结构,称为进程控制块(PCB),用来描述进程的各种信息(如程序代码的存放位置)。


2.1.1.2 进程的定义

程序段、数据段、PCB三部分组成了进程实体(进程映像)。一般情况下,我们把进程实体就简称为进程;所谓创建进程,实质上就是创建进程实体中的PCB;而撤销进程,实质上就是撤销进程实体中的PCB。也就是说,PCB是进程存在的唯一标志。

从不同的角度,进程可以有不同的定义,比较传统典型的定义有:

  1. 进程是程序的一次执行过程。
  2. 进程是一个程序及其数据在处理机上顺序执行时所发生的活动
  3. 进程是具有独立功能的程序在数据集合上运行的过程,它是系统进行资源分配和调度的一个独立单位。

三个定义无不在反映一件事:进程是动态的。

引入进程实体的概念后,我把可以把进程定义为:进程是进程实体的运行过程,是系统进行资源分配和调度的一个独立单位。严格来说,进程和进程实体并不一样,进程实体是静态的,而进程是动态的。除非题目专门考查二者区别,否则我们通常认为进程实体就是进程。因此我们也可以说“进程是由程序段、数据段、PCB三部分组成。”


2.1.1.3 进程的组成

从内存的视角来看,进程由如图所示的三部分组成:image-20220118111352974

从PCB的角度看,PCB由如图所示的结构构成:

image-20220118112104616

  • 进程标识符PID用于进程创建时,操作系统用区分不同的进程,其类似于身份证号。当进程被创建的时候,操作系统就会为该进程分配一个唯一的、不重复的ID。
  • 用户标识符UID用于标识进程所属的用户是谁。
  • 其余的东西后面会细讲这里不多说。
  • 处理器相关信息主要是指一些寄存器的值。当进程切换时,我们需要把进程当前的运行情况记录下来保存在PCB中,比如程序计数器的值表示了当前程序执行到哪一句。

从进程的组成来看:

image-20220118142739911

2.1.1.4 进程的组织

在一个系统中,通常有数十、数百乃至数千个PCB。为了对他们加以有效的管理,应当用适当的方式把这些PCB组织起来。

需要注意的是,进程的组成讨论的是一个进程内部由哪些部分构成的问题,而进程的组织讨论的是多个进程之间的组织方式问题。

从进程的组织方式来看,分为两类,分别如下:

image-20220118143119351


2.1.1.5 链接方式

链接方式的工作流程如下图,这里不过多赘述。image-20220118143353240


2.1.1.6 索引方式

索引方式的工作流程如下图,这里不过多赘述。

image-20220118143549001


2.1.1.7 进程的特征

进程和程序是两个截然不同的概念,相比于程序,进程拥有以下特征:

image-20220118143828025


2.1.1.8 小结

image-20220118144047663


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/398779.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

服务器换账号登陆不了怎么办,怎么切换账号 更换账号 注册新的账号小技巧分享给你...

很多玩家喜欢多尝试几种玩法,那么万国觉醒怎么切换账号?切换账号后玩家如何再重新登入游戏?如何在多个账号中快速切换?今天小编就跟大家说说万国觉醒快速切换账号登入游戏的技巧。一、切换账号介绍我们常说的切换账号有两种意思&a…

vue基本介绍

https://cn.vuejs.org/v2/guide/ Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架。与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用。Vue 的核心库只关注视图层,不仅易于上手,还便于与第三方库或既…

android控件的隐藏与显示

2019独角兽企业重金招聘Python工程师标准>>> visibility:显示 invisibility:不显示,不可见但是仍然占据空间 gone:不显示,不可见不占用空间 view.setVisibility();----设置值:0代表visibility&a…

《BI那点儿事》Microsoft 线性回归算法

Microsoft 线性回归算法是 Microsoft 决策树算法的一种变体,有助于计算依赖变量和独立变量之间的线性关系,然后使用该关系进行预测。该关系采用的表示形式是最能代表数据序列的线的公式。例如,以下关系图中的线是数据最可能的线性表示形式。 …

王道操作系统考研笔记——2.1.2 进程的状态和转换

如果这篇博客对您有用的话,可以给我点个赞吗,这对我很重要,谢谢!❤️ 2.1.2 进程的状态和转换 知识总览 2.1.2.1 三种基本状态 进程是程序的一次执行。在这个执行过程中,有时进程正在被CPU处理,有时又需要…

PHP表达式

自定义常量define()函数:专门用于定义自定义常量; 语法格式:define(name,value[,boolean case_insensitive]);函数功能:定义一个名字为name,值为value的常量。 case_insensitive参数的默认值为FALSE,…

Java中抽象类和接口在概念、语法和应用上的区别和关系

2019独角兽企业重金招聘Python工程师标准>>> 春招开始了,盆友们都忙着准备笔试、准备面试,复习学过的知识点,当然我也不例外,在这里祝每一个"有心人"心想事成,梦圆2016,加油&#xff…

跳槽

2008年6月26日 阴天多云 辞职前第16日 土耳其不争气,害的我输了近4000分的可用分,最为倒霉的是它尽然先进球,给了我那么多的希望。还有就是直播过程中突然的长时间的无信号,输都不知道怎么输的。 今天瞌睡比较重,上班的…

辨半表半里证

半表半里证是指病邪既不在表,又非完全入里,介于表里之间的证候。本证多因外邪由表传内,尚未入于里;或里邪透表,尚未达于表,邪气留居半表半里,或邪气直犯少阳,正气渐虚,正…

王道操作系统考研笔记——2.1.3 进程控制

如果这篇博客对您有用的话,可以给我点个赞吗,这对我很重要,谢谢!❤️ 2.1.3 进程控制 知识总览 2.1.3.1 进程控制的过程 进程控制的主要功能是对系统中的所有进程实施有效的管理,它具有创建新进程、撤销已有进程、实…

MySQL之——GROUP BY分组取字段最大值

转载自:http://blog.csdn.net/l1028386804/article/details/54657412 假设有一个业务场景,需要查询用户登录记录信息,其中表结构如下: [sql] view plaincopyCREATE TABLE tb ( id int(11) NOT NULL AUTO_INCREMENT, uid int…

王道操作系统考研笔记——2.1.4 进程通信

如果这篇博客对您有用的话,可以给我点个赞吗,这对我很重要,谢谢!❤️ 2.1.4 进程通信 知识总览 2.1.4.1 什么是进程通信 顾名思义,进程通信就是指进程之间的信息交换。 进程是分配系统资源的单位(包括内…

paper 35 :交叉验证(CrossValidation)方法思想

交叉验证(CrossValidation)方法思想简介以下简称交叉验证(Cross Validation)为CV.CV是用来验证分类器的性能一种统计分析方法,基本思想是把在某种意义下将原始数据(dataset)进行分组,一部分做为训练集(train set),另一部分做为验证集(validation set),首先用训练集对分类器进行…

strerror和perror函数详解

/*#include <string.h> char *strerror(int errnum); 它返回errnum的值所对应的错误提示信息&#xff0c;例如errnum等于12的话&#xff0c;它就会返回"Cannot allocate memory"。 测试程序&#xff1a;*/ #include <stdio.h> #include <string.h>…

【2018-01-28】HTML-布局

位置&#xff1a; position&#xff1a;fixed 固定 absolute 绝对位置 relative 相对位置 top right     bottom left 流&#xff1a; float&#xff1a;left 向左流 right 向右流 both 清掉流 z-index分层&#xff1a; 值越大越靠上转载于:https://www.cnblogs.com/zqyyx…

关于设计模式——策略模式-Strategy Pattern

文章目录1 策略模式1.1 模拟鸭子1.2 设计原则1.3 整合行为1.4 模拟鸭子代码的代码1.5 动态设定行为1.6 重新查看整体1.7 继承和组合1.8 总结1.9 优劣期间应用场景2.0 参照资料1 策略模式 在我们什么都不会的情况下&#xff0c;我们先无需知道什么是策略模式&#xff0c;我们要…

python (3):wxPython打包app,报错

1&#xff0c;打包app报错 如图&#xff1a; 使用py2app&#xff0c;mac下打包成app。异常。程序直接退出。 没有详细的错误信息&#xff0c;client程序直接崩溃了。 2。原因 代码没有几行&#xff1a; #!/usr/bin/python # -*- coding: utf-8 -*- import wxapp wx.App(False…

.NET Framework 工具

您可以使用 .NET Framework 工具轻松创建、部署和管理面向 .NET Framework 的应用程序和组件。 此节中介绍的大部分 .NET Framework 工具将自动随 Visual Studio 一起安装。 &#xff08;有关安装信息&#xff0c;请参阅 Visual Studio 下载。&#xff09; 可以从命令行运行除程…

并发无锁队列学习(概念介绍)

1、前言 队列在计算机中很重要的一种数据结构&#xff0c;尤其在操作系统中。队列典型的特征是先进先出&#xff08;FIFO&#xff09;&#xff0c;符合流水线业务流程。在进程间通信、网络通信之间常常採用队列做缓存&#xff0c;缓解数据处理压力。结合自己在工作中遇到的队列…

王道操作系统考研笔记——2.1.5 线程概念与多线程模型

文章目录2.1.5 线程概念与多线程模型2.1.5.1 线程的来源2.1.5.2 线程机制带来的变化2.1.5.3 线程的属性2.1.5.4 线程的实现方式2.1.5.5 多线程模型2.1.5.6 小结2.1.5 线程概念与多线程模型 2.1.5.1 线程的来源 在很久以前还没有引入进程之前&#xff0c;系统中的各个程序只能…