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

news2024/11/13 11:49:21

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

目录

一:操作系统

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.coloradmin.cn/o/2145533.html

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

相关文章

硬件开篇——体系架构

1、驱动开发分类: 裸机驱动(无操作系统)——由寄存器控制;Linux驱动。 硬件: 计算机系统: 计算机架构:①冯诺依曼(指令、数据一起)②哈佛(指令、数据分开&a…

【BoF】《Bag of Freebies for Training Object Detection Neural Networks》

arXiv-2019 https://github.com/dmlc/gluon-cv 文章目录 1 Background and Motivation2 Related Work3 Advantages / Contributions4 Method4.1 Visually Coherent Image Mixup for Object Detection4.2 Classification Head Label Smoothing4.3 Data Preprocessing4.4 Traini…

如何使用ssm实现理财通的设计与实现

TOC ssm638理财通的设计与实现jsp 第一章 绪论 1.1 选题背景 目前整个社会发展的速度,严重依赖于互联网,如果没有了互联网的存在,市场可能会一蹶不振,严重影响经济的发展水平,影响人们的生活质量。计算机的发展&am…

功能测试干了三年,快要废了。。。

8年前刚进入到IT行业,到现在学习软件测试的人越来越多,所以在这我想结合自己的一些看法给大家提一些建议。 最近聊到软件测试的行业内卷,越来越多的转行和大学生进入测试行业,导致软件测试已经饱和了,想要获得更好的待…

Linux提升篇-服务器BIOS介绍

目录 前言BIOS 概述常用配置进入 BIOS 界面查询 iBMCIP 地址设置 BIOS 系统日期和时间设置服务器启动方式 前言 以下bios介绍适用于大部分2020年之后的服务器,包括Huawei系的鲲鹏CPU架构服务器,X86系也可参考,大部分配置项是一致的。 BIOS …

【Java】线程的同步——synchronized、ReentrantLock

对同一个线程,能否在获取到锁以后继续获取同一个锁? 答案是肯定可以获取同一个锁。因为JVM 允许同一个线程重复获取同一个锁,这种能被同一个线程反复获取的锁,就叫做可重入锁。 一、synchronized同步锁 在 Java中synchronized 同步锁…

HbuilderX自定义快捷键

打开快捷键设置:工具->自定义快捷键 复制想要修改的快捷键设置 修改后记得保存 可以通过该方法找到对应功能的系统默认快捷键

[数据集][目标检测]智慧养殖场肉鸡健康状态检测数据集VOC+YOLO格式4657张2类别

数据集格式:Pascal VOC格式YOLO格式(不包含分割路径的txt文件,仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数):4657 标注数量(xml文件个数):4657 标注数量(txt文件个数):4657 标注…

用ASR PRO离线语音芯片和月饼盒做一个会跑会跳会说话的机器狗

中秋节刚过,大家月饼盒应该还有,不要扔,可以做点小玩意。 机器狗的创意来自B站石桥北的视频,他使用了一块ESP32芯片和打印件加四个舵机实现,应该说是比较复杂的,需要有3D打印机打印外壳,还得会…

Hadoop的一些高频面试题 --- hdfs、mapreduce以及yarn的面试题

文章目录 一、HDFS1、Hadoop的三大组成部分2、本地模式和伪分布模式的区别是什么3、什么是HDFS4、如何单独启动namenode5、hdfs的写入流程6、hdfs的读取流程7、hdfs为什么不能存储小文件8、secondaryNameNode的运行原理9、hadoop集群启动后离开安全模式的条件10、hdfs集群的开机…

TortoiseSVN图标不显示的解决

解决办法一:修改svn软件的图标设置 1、选中一个文件夹或在桌面空白处,右击进入svn的setting 2、进入setting->Icon Overlays,Status cache选择Default或shell,然后点击应用 3、查看文件,图标可以正常显示 解决办法…

ubuntu下载安装部署docker,ubuntu下载最新的docker

1.#如果Ubuntu自带的Docker版本太低,我们需要卸载旧版本并安装新的 sudo apt-get remove docker docker-engine docker.io containerd runc2.# 备份原有软件源 sudo cp /etc/apt/sources.list /etc/apt/sources.list.bak3.选择合适的镜像源 # 或者使用清华大学sudo…

利用WPF绘制轮廓并保存为图片

1.前言 WPF作为显示工具也挺好用,用C#开发应用软件会比较省力,当然也有其缺点,如在对效率要求较高的情况下有性能问题,本文记录用WPF绘制轮廓并保存为图片相关内容。 显示效果也还不错,满足调试使用了&#xf…

变电站缺陷数据集8307张,带xml标注和txt标注,可以直接用于yolo训练

变电站缺陷数据集8307张, 带xml标注和txt标注,可以直接用于yolo训练,赠附五个脚本 变电站缺陷数据集 数据集概述 变电站缺陷数据集是一个专门针对变电站设备和环境缺陷检测的图像数据集。该数据集包含了8307张经过标注的图像,旨…

Maven和Springboot初识

(一)Maven Maven是一个项目管理工具,通过一小段描述信息来管理项目的构建,报告和文档的项目管理工具 (可以通过pom.xml文件的配置来获取jar包,而不用手动添加) Maven可以提高我们的开发效率减少…

Mistral AI 又又又开源了闭源企业级模型——Mistral-Small-Instruct-2409

就在不久前,Mistral 公司在开源了 Pixtral 12B 视觉多模态大模型之后,又开源了自家的企业级小型模型 Mistral-Small-Instruct-2409 (22B),这是 Mistral AI 最新的企业级小型模型,是 Mistral Small v24.02 的…

C++源代码封装成dll动态链接库,并在WPF项目中使用的步骤说明

文章目录 1. 创建并生成C的DLL(C动态链接库)(1)新建项目-->开发语言选定C,在搜索栏搜索“动态链接库”-->配置项目名称和路径-->添加类,此处命名为My_C_Class(2)实现类的功能&#xff…

Elasticsearch 下载安装及使用总结

官网文档地址:Elasticsearch Guide [8.13] 官网下载地址:Download Elasticsearch 1. 下载安装 1、下载对应系统的版本 这里下载的 Elasticsearch 版本为 8.13.2,Elasticsearch 依赖 Java,因此要先在服务器上安装 JDK&#xff…

SOLIDWORKS® 2025 新增功能 - SIMULATION

SOLIDWORKS Simulation 1常规弹簧连接 • 通过定义仅轴向、各向同性或正交各向异性弹簧, 在曲面之间轻松创建自定义弹簧连接。 • 通过添加自定义合规性提高仿真性能和精度。 优点 利用新的弹簧连接功能, 实现更简单、更逼真的仿真 设置。 2增强了…

Unity 百度AI实现无绿幕拍照抠像功能(详解版)

目录 一、前言 1.抠像效果 2.去哪找百度ai抠图 3.基础流程跳过 二、获取AccessToken 1.什么是Token 2.为什么要获取Token 3.如何获取token 4.解析json 5.完整代码 三、抠像 1.准备地址 2.建立链接,和基本配置 3.图片格式转换 4.开始上传 5.获取回复…