4.4、 Linux进程排队

news/2024/6/17 20:00:17 标签: Linux

个人主页:Lei宝啊 

愿所有美好如期而遇


前言

如果后续讲解看不懂,请移步先看完前导知识

Linux操作系统上icon-default.png?t=N7T8https://blog.csdn.net/m0_74824254/article/details/134385952?spm=1001.2014.3001.5501Linux操作系统下icon-default.png?t=N7T8https://blog.csdn.net/m0_74824254/article/details/134506893?spm=1001.2014.3001.5501Linux进程icon-default.png?t=N7T8https://blog.csdn.net/m0_74824254/article/details/134512685?spm=1001.2014.3001.5501


狭义上我们说,进程 = 内核数据结果 + 可执行程序代码和数据,进程排队,一定是进程在等待某种资源,可以是CPU,磁盘,键盘,也可以是软件资源,而且我们要明白,进程排队一定是他的task_struct在排队,不是可执行程序在排队。

进程不是一直都在运行,就算是已经放在了CPU上,CPU也不会一直去跑一个进程,我们写一个死循环并执行他,也只是有些卡顿,其他进程依然在跑,并不是说一直执行这个死循环,这里我们引入时间片这个概念,CPU执行进程是有一个时间的,就比如说给你执行1ms以后,去执行其他进程1ms,而不是一个进程一直跑,否则这个死循环占着CPU不下来一直执行,其他进程不就无法执行了吗,但现实是我们尽管卡了点,但是其他进程运行正常。

一个CPU只有一个运行队列,也就是说几个CPU,就有几个运行队列,我们一般人用的都是单CPU,所以只有一个运行队列。

我们前面说到可执行程序加载到内存中,操作系统要管理他,于是就先用task_struct描述起来,接着再用链表组织起来,这里的链表是双链表,而且不同于我们平常意义上的双链表,那么我们运行他,就必然要把他加入CPU的运行队列里,那么这个链表怎么办,难道移除不让操作系统管理了吗?

首先我们要说到的是task_struct可以被连入多个数据结构中,接下来看图

task_struct里可以通过增加listnode节点来找到其他进程,同时也让我们不用去以移除进程来达到连入运行队列的目的,但是你也许会有疑问,节点在中间,前面的数据你怎么找,如何拿到进程控制块的首地址?

这样我们就可以将进程连入任意数据结构中,而且还可以让操作系统很好的管理他们,不需要移除链表。

这样我们也就明白了进程是如何连入CPU运行队列的,我们要说到的是,只有在CPU运行队列里的进程,才是运行状态,等待资源,卡住不动的是阻塞或者挂起状态。

他们在CPU上如何排队我们也就知道了

那么当进程处于阻塞状态,比如一个可执行程序里有scanf函数,需要键盘资源,当运行到scanf时,就会处于阻塞状态,此时进程就会从运行队列里拿下来,连入到描述键盘的结构体,看图

等到键盘输入后,这个进程才会再次连入运行列表。

其实在我的理解中,CPU也是硬件,他也是device,所以他的结构应该和上图一样,只是叫做运行队列,更准确点,应该是这样

进程都是在需要某种资源,需要什么,就连入那里。


http://www.niftyadmin.cn/n/5208884.html

相关文章

element plus 使用细节

菜鸟一直在纠结这个写不写,因为不难,但是菜鸟老是容易忘记,虽然想想或者搜搜就可以马上写出来,但是感觉每次那样就太麻烦了,不如一股做气写了算了,后面遇见别的就再来补充! 文章目录 table 表格…

python3实现类似expect shell的交互式与SFTP的脚本

前面写过一篇关于python实现类似expect shell的交互式能力的文章,现在补全一下加上sftp的能力脚本。 例子在代码中__example()方法。 依赖paramiko库,所以需要执行pip install paramiko来安装。 import os import queue import re import threading im…

HTML新手入门笔记整理:特殊符号

音标符 音标符 字符 Construct 输出结果 ̀、 a a à ́′ a a án ˆ a a â ̃&#xff5e; a a ã ̀̀、 O O Ò ́́′ O O Ó ˆ O O Ô ̃&#xff5e; O O Õ 字符 显示结果 描述 实体名称 实体编号 空格 <…

C++二分向量算法:最多可以参加的会议数目 II

本题的其它解法 C二分算法&#xff1a;最多可以参加的会议数目 II 本文涉及的基础知识点 二分查找算法合集 题目 给你一个 events 数组&#xff0c;其中 events[i] [startDayi, endDayi, valuei] &#xff0c;表示第 i 个会议在 startDayi 天开始&#xff0c;第 endDayi …

STM32_6(TIM)

TIM定时器&#xff08;第一部分&#xff09; TIM&#xff08;Timer&#xff09;定时器定时器可以对输入的时钟进行计数&#xff0c;并在计数值达到设定值时触发中断16位计数器、预分频器、自动重装寄存器的时基单元&#xff0c;在72MHz计数时钟下可以实现最大59.65s的定时不仅…

从0开始学习JavaScript--JavaScript元编程

JavaScript作为一门灵活的动态语言&#xff0c;具备强大的元编程能力。元编程是一种通过操作程序自身结构的编程方式&#xff0c;使得程序能够在运行时动态地创建、修改、查询自身的结构和行为。本文将深入探讨JavaScript中元编程的各个方面&#xff0c;包括原型、反射、代理等…

node版本管理工具-nvm

1、 下载地址 https://github.com/coreybutler/nvm-windows/releases/tag/1.1.11 2、 选择安装地址不能有空格&#xff0c;中文 3、 使用命令

某60区块链安全之未初始化的存储指针实战一学习记录

区块链安全 文章目录 区块链安全未初始化的存储指针实战一实验目的实验环境实验工具实验原理实验过程 未初始化的存储指针实战一 实验目的 学会使用python3的web3模块 学会分析以太坊智能合约未初始化的存储指针漏洞 找到合约漏洞进行分析并形成利用 实验环境 Ubuntu18.04操…