[JavaEE]———进程、进程的数据结构、进程的调度

阿华代码,不是逆风,就是我疯,你们的点赞收藏是我前进最大的动力!!希望本文内容能帮到你!

目录

一:操作系统

1:操作系统的定位和功能

2:多任务操作系统

3:单任务操作系统

二:进程、任务

1:进程概念

2:进程是“系统分配资源”的基本单位

3:操作系统的进程管理

 (0)PCB

(1)描述PCB

(2)组织PCB

(3)实例

(4)PID

(5)内存指针

(6)文件描述符表

三:进程的调度

1:分时复用,并发执行

2:并行执行

3:并发编程

4:状态

(1):就绪状态

(2):阻塞状态

5:优先级

6:记账信息

7:上下文


引入:软件工程的本质,针对“复杂程度”的管理,管理的本质就是“抽象和封装”

一:操作系统

1:操作系统的定位和功能

(1)管理各种硬件设备

(2)给软件提供稳定的运行环境

2:多任务操作系统

顾名思义,在同一时刻,后台可以有多个应用程序,比如我可以开着qq,微信聊天,听着网易云,时不时刷刷知乎........

3:单任务操作系统

一个时刻只能有一个程序,像以前市面上的山寨机,多是这种操作系统,

二:进程、任务

1:进程概念

正在运行的程序就叫做进程或者任务

2:进程是“系统分配资源”的基本单位

每个任务在执行的过程的当中,都需要消耗一定的硬件资源。换而言之(等价说法),进程在运行过程中,都需要给进程分配系统资源。

3:操作系统的进程管理

简述(具体过程比下文更加复杂):

 (0)PCB

①PCB:表示进程信息的结构体进程控制块(Process Control Block)简称为PCB,这个概念是操作系统中通用的概念

在Linux上PCB具体表现为一个叫做 struck task_struck{......}这样的一个结构体。

②类/结构体:用来描述一些实体的属性的集合

(1)描述PCB

通过PCB来描述实体的属性

(2)组织PCB

通过数据结构,把这些进程控制块串在一起

在Linux中,通常用链表来把若干个进程控制块串联在一起

(3)实例

在我们打开任务管理器的时候会显示很多进程,其实就是系统在遍历链表后,打印链表上节点的信息。

如果运行一个新的程序,系统就会多一个进程,就需要构造一个新的PCB,并把这个PCB加入到链表的节点中去

如果退出一个进程,就把对应的PCB在链表上删除,并且回收掉相关的PCB的资源

(4)PID

PID是PCB的核心属性之一

PID是进程的身份标识,具体表现形式为,一个整数,同一台机器,同一时刻,每一个进程都有一个不同的整数数字标号,后续如果要对进程进行一些操作,我们就可以根据这个数字来区分进程

比如:当我们要结束一个进程的时候,选中进程,点击结束任务,任务管理器获取到这个进程的PID,然后调用一个系统API,把这个pid作为参数传入,最后完成杀死进程的一个操作

(5)内存指针

内存指针就是描述进程使用内存资源的详细情况。

进程在运行起来之前,需要向系统申请一块内存空间,系统同意后给进程分配内存资源,进程才可以运行,

进程运行起来之后,也需要和“数据”“指令”进行配合,所以进程需要知道哪里存的是“数据”,哪里存的是“指令”

(注:数据和指令也都是需要存到内存当中的,在进程跑起来之前,数据和内存就需要提起加载到内存当中去)

打个比方:进程现在要去住旅馆,像旅馆馆主申请房间,馆主同意后分配给你一个房间,你就只能在这个房间中活动,

(6)文件描述符表

文件描述符表是用来描述进程所涉及到的硬盘资源

存储器=内存+外存,外存包括但不限于(硬盘,光碟,u盘,软盘等),因为现在硬盘居多,所以我们说的外存默认都指硬盘。

进程想要修改文件,那么就得先“打开文件”——:在文件描述符表上分配一个表项,构造一个结构体,来描述这个文件的实体信息

三:进程的调度

背景描述:进程在运行的时候需要消耗占用一定的CPU资源,而在同一台机器同一时刻有5个进程需要“同时”运行,那cpu是如何处理的呢?

1:分时复用,并发执行

打个比方——只有一个单核CPU(一个舞台),现在需要5个进程同时运行(上舞台表演),(同一时刻,同意舞台只能有一个进程)怎么办,那就只能压缩每个进程表演的时间,(进程ABCDE超速轮回切换上台),人是感知不到这个切换的过程的(因为cpu的频率足够高),这样肉眼就会误以为是五个进程在“同时运行”。

当然也有极端情况,进程数量太多了,cpu处理不过来,表现出来就是系统卡顿,鼠标转圈。

2:并行执行

同样打比方——现在我们有一个四核cpu,8个进程,同样要让这些进程满足同一时刻,同一舞台,只能有一个进程表演,要达到肉眼难以区分的切换速度,这个过程就要复杂许多了

但是这里任然满足“分时复用,并发执行”这一概念,在此基础上多了一条“并行执行”(因为舞台数多了嘛)

3:并发编程

我们现在计算机的执行过程是 “并发执行”+“并行执行”同时存在的,所以我们就把这两者结合统一叫成“并发编程”

但是两个进程如何运行需要看系统如何调度,这里涉及到系统调度器模块的实现(略)

4:状态

状态是描述进程是否能被cpu调用执行

(1):就绪状态

进程此时空闲,整装待发,操作系统知乎一声,进程直接就上cpu那开始干活了

(2):阻塞状态

也可以理解成进程正在等待,比如用户调用Scanner,进程需要等待用户输入东西,在这个过程中,进程是不方便被操作系统调用去干别的事的,这就是阻塞状态。

5:优先级

我们在前面说了,舞台只有4个,但是我有很多个进程,那么谁先上呢?这里就涉及到一个优先级的问题了,看那个进程比较重要,由操作系统来进行统一调配。

比如:我在打王者农药,同时又挂着微信,此时有人给我发消息,系统肯定是先紧着农药,消息晚点收也无所谓~~~~这就是优先级

6:记账信息

这个概念也很好理解,,这个红字中怎么判断,哪个进程重要呢?这就涉及到了记账信息。

我们还是用进程舞台演出的例子哈,在一个轮次中,每个进程表演的时间不同(即进程在CPU中占用的时间比例不同),我们统计这一轮中进程的时间占比,作为记账信息,在下一轮中操作系统根据这个信息来对新一轮的进程进行优先级安排。

7:上下文

也是pcb(进程控制模块)中的一种数据结构,支撑进程调度的重要属性之一,相当于单机游戏中的存档和读档。

1:存档

在进程被cpu调度之前,把普通寄存器当中的信息,单独保存到一个地方(一般是内存的关键寄存器中),不要让这些信息被覆盖或者消失。

2:读档:

在下一次进程被cpu调度之前,把关键寄存器当中的信息给恢复加载到普通寄存器当中

注:无论存档还是读档都是在cpu调度进程之前

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

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

企业常用的8款文件加密软件分享|2024办公文件怎么加密?

随着数字化办公的深入,企业文件安全变得至关重要。企业需要确保敏感数据在传输、存储和共享过程中不会被非法访问或泄露。文件加密是最有效的安全措施之一,通过加密技术,将文件转化为不可读的加密文本,只有授权的用户可以解密查看…

若依VUE项目安全kind-of postcss vite漏洞扫描和修复

npm install unplugin-auto-import0.16.7 npm install vite3.2.11 升级vite、unplugin-auto-import npm install 报错New major version of npm available! 8.5.5 -> 10.8.3,使用命令npm install --force npm install --force

VisionPro - 基础 - 00 模板匹配技术和在VP中的使用 - PMAlign - PatMax - (2)

前言: 针对PatMax 的高级应用和原理,在这一节进行说明: PatMax Patterns When you train PatMax you specify a region of interest in an image or provide a description of a shape that includes the features you want to train. If yo…

Mac电脑技巧:通过 5 种方法从 Mac 上的 SD 卡恢复已删除的文件

SD 卡重量轻且便于携带,是广受欢迎的存储设备。它们通常用于相机、车载录像机、安全门铃等。假设您是一位摄影爱好者,使用 SD 卡来存储您珍贵的回忆:您需要意识到,与易用性相反的是其易碎性,这意味着 SD 卡上的数据可能…

最好的十大儿童护眼灯品牌有哪些?十大护眼大路灯品牌排行榜

最好的十大儿童护眼灯品牌有哪些?作为一名宝爸兼测评博主,对于孩子的视力健康我是极其关注的,可以说经常跟护眼灯打交道。一开始在这方面上我也踩雷不少坑!测评用过这么多护眼大路灯最大的感受就是,有些护眼大路灯完全…

Redis技术解析(基础篇)

1.初识Redis Redis是一种键值型的NoSql数据库,这里有两个关键字: 键值型 Redis-server NoSql 其中键值型,是指Redis中存储的数据都是以key、value对的形式存储,而value的形式多种多样,可以是字符串、数值、甚至jso…

莲藕炖排骨-UMLChina建模知识竞赛第5赛季第15轮

DDD领域驱动设计批评文集 做强化自测题获得“软件方法建模师”称号 《软件方法》各章合集 只要最先答对前3题,即可获得本轮优胜。 如果有第4题,第4题为附加题,对错不影响优胜者的判定,影响的是优胜者的得分。 所有题目的回答必…

2024/9/19 英语每日一段

One driver told the Guardian that when the renewal quote for her Saga over-50s car insurance arrived, the cost of the policy had jumped 77% to £2,044 even though “nothing has changed”. Saga said it was experiencing “high levels of claims infl…

【笔记】扩散模型(八):DALL-E 2 (unCLIP) 论文解读与代码实现

论文链接:Hierarchical Text-Conditional Image Generation with CLIP Latents 非官方实现:lucidrains/DALLE2-pytorch DALL-E 2 是一个比较经典的文生图模型,虽然和 Stable Diffusion 的架构有些区别,但是也利用了 CLIP 的文本-图…

2024CCPC网络赛

vp链接&#xff1a;Dashboard - The 2024 CCPC Online Contest - Codeforces B. 军训 II 序列 a 从小到大排列或者从大到小排列时&#xff0c;不整齐度是最小的。方案数是所有相同数字的个数的排列数的乘积。如果首尾的数字不同的话&#xff0c;还要再乘个 2。 #include <…

【在Linux世界中追寻伟大的One Piece】进程间关系与守护进程

目录 1 -> 进程组 1.1 -> 什么是进程组 1.2 -> 组长进程 2 -> 会话 2.1 -> 什么是会话 2.2 -> 如何创建会话 2.3 -> 会话ID(SID) 3 -> 控制终端 4 -> 作业控制 4.1 -> 什么是作业(job)和作业控制(Job Control) 4.2 -> 作业号 4.3…

【他山之石】优化 JavaScript 的乐趣与价值(下)

前言 继本文的 上篇 发表之后&#xff0c;没想到反响还挺好&#xff0c;看来大家在 JS 优化的问题上越来越注重“与国际接轨”了。一起来看本文的下篇&#xff0c;也是干货满满。 文章目录 6. Avoid large objectsWhat the eff should I do about this? 7. Use eval8. Use str…

Linux用户账号管理

目录 一、useradd 创建新用户 二、usermod 修改用户账号 三、userdel 删除用户账号 四、passwd 设置或更改用户密码 五、who 或 w 查看当前登录用户 六、切换用户 6.1. su命令切换用户 6.2. sudo授权命令 6.2.1. sudo的特性 6.2.2. sudo的相关文件 6.3. exit退出 6…

自制数据库迁移工具-C版-04-HappySunshineV1.4-(支持Gbase8a、PG)

目录 一、环境信息 二、简述 三、架构图 四、升级点 五、支持功能 六、安装包下载地址 七、配置参数介绍 八、安装步骤 1、配置环境变量 2、生效环境变量 3、检验动态链接是否正常 4、修改配置文件MigrationConfig.txt &#xff08;1&#xff09;Gbase8a -> Gba…

Axios基本语法和前后端交互

Axios是一个js框架&#xff0c;用于发送ajax请求。 一、导入 // node中&#xff0c;使用npm安装 npm install axios // HTML中&#xff0c;使用cdn安装 <script src"https://unpkg.com/axios/dist/axios.min.js"></script> 二、基本使用 // 使用axios…

x264中的cabac编码实现

typedef struct { /* state */ int i_low; //概率状态的范围low int i_range; //当前概率状态 范围range /* bit stream */ int i_queue; //stored with an offset of -8 for faster asm 队列中可输出的bits 个数&#xff0c;-8 开始&#xff0c;是为了方便asm优化 int i_byt…

数据防泄密系统的构建与功能分析(实用物料)

一、构建1、需求分析&#xff1a;明确企业需要保护的敏感数据类型&#xff08;如商业机密、研发资料等&#xff09;及其潜在的泄露途径&#xff08;如网络传输、文件共享、打印复印等&#xff09;。 2、策略&#xff1a;根据需求分析结果&#xff0c;制定详细的数据防泄密策略…

数字逻辑电路-加法器

目录 半加器和全加器 半加器 ​全加器 集成全加器 利用全加器实现二进制的乘法功能 加法器 半加器和全加器 半加器 不考虑低位进位的加法。 本位为s&#xff0c;进位为c。 全加器 多了一个相邻低位来的进位数。 集成全加器 左上角和右下角那两个是不用的。 利用全加器…

Selenium通过ActionBuilder模拟鼠标操作直接移动到指定坐标的注意事项

在目前&#xff08;2024-09-18&#xff09;得Selenium官方手册中&#xff0c;模拟鼠标操作基本上都是通过ActionChains完成的&#xff0c;唯独有一动作&#xff0c;是通过ActionBuilder完成的。 而前者ActionChains&#xff0c;主要是通过offset&#xff0c;也就是坐标偏移量来…

RK3568笔记五十九:FastSAM部署

若该文为原创文章,转载请注明原文出处。 记录FastSAM训练到部署全过程,转换模型和yolov8一样。 一、介绍 Fast Segment Anything Model (FastSAM) 是一种基于 CNN 的新型实时解决方案,可用于 Segment Anything 任务。该任务旨在根据各种可能的用户交互提示分割图像中的任何…