波奇学Linux:Linux进程状态,进程优先级

编写一个程序模拟进程

查看进程状态

修改代码后发现进程状态为由S+变成R+ 

R为运行态,S为阻塞态

第一次为S是因为调用了外设(printf调用屏幕外设),实际上应该为R,S状态轮换,但是R太快了,所以每次查到了都为S。

R+为前台运行,运行bash指令无反应。

R加入& 为后台运行,可以运行bash指令,此时只能用kill指令来取消进程

大部分的程序都属于sleep状态,等待资源输入,比如scanf和bash命令行。

D状态(Disk sleep):深度睡眠的阻塞态

S状态叫做前度睡眠,可以被外部操作唤醒,如外部输入kill指令关掉进程。

当进程把数据从内存写入磁盘,进程进入S状态。

当资源压力太大,操作系统可以杀掉进程,为了防止写入磁盘的进程被杀掉,进程进入D状态,进程就不能被杀死。

D状态不响应操作系统的任何操作。当高I/O状态下,才能看到D状态。

T状态:暂停进程

19号命令取消进程,18号命令唤醒暂停的指令。

T状态和S状态区别,S状态常用于等待资源。两种都是阻塞状态

t,X,Z状态

t状态(trace stop):暂停状态的一种,同样也是阻塞状态,常被用于断点处

X(dead):终止态,进程结束

Z(zombie):僵尸态,进入X状态前进入Z状态。

Z状态会在X状态前维持进程状态等信息。传递信息等给父进程。

编写父子进程,此时父进程没有对子进程做任何事情,子进程退出,保持僵尸态。

 

进程一般退出时,如果父进程没有主动回收,子进程信息,子进程一直让自己出于z状态,进程的相关资源尤其是task_struct结构体不能被释放。

如果父进程一直不释放,会造成资源浪费。

父进程先于子进程销毁

此时运行的子进程的父进程变成操作系统(操作系统pid为1)

 该进程被系统领养,该子进程也叫孤儿进程,该进程的资源被系统回收。

直接kill能让父子进程都销毁。

进程优先级

进程饥饿:如果进程长时间得不到cpu资源,该进程的代码长时间无法得到推进,该进程的饥饿问题。优先权高的进程有优先执行权利。

UID表示执行者身份boki的uid就是 1002

PRI(priority):80,这个值越小,优先级越高

NI(nice):进程的nice值,进程优先级修正数据,默认的nice值范围是[-20,19)。

PRI(new)=PRI(old) +nice 通过修改nice值可以修改优先级,nice改成负数,PRI变小优先级变高

nice指令和renice指令可以修改优先级

查找进程PID

top指令,按r修改进程的nice值(修改后只会是-20)

其中PRI(old)是从永远从80开始

哈希开散列法实现操作系统优先级调度

struct runqueue中有running和waiting两个指针数组。

PCB会根据PRI的值映射到running数组中,数组跟据优先级由上往下获取取PCB运行进程,如果优先级相同则在添加在PCB1后,先从左往右,再往下直到数组中全部进程运行完毕。

waiting是镜像数组,当负责接收进程,把running中的提取和waiting的接收分开,接收规则和runing一样。当running数组空了后,wait和run指针指向的数组swap()。

用bitmap来判断running数组是否为空。根据0,1判断数组对应位置是否有PCB指针。

 

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

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

相关文章

中国区县人工智能企业数量,shp/excel格式,数据全,覆盖2010-2023年

基本信息. 数据名称: 中国区县人工智能企业数量 数据格式: Shpexcel 数据时间: 2010-2023年 数据几何类型: 面 数据坐标系: WGS84 数据来源:网络公开数据 数据字段:见【吧唧数据】www.bajidata.com 1a2023人工智能企业数量(个&…

模块二——滑动窗口:3.无重复字符的最长子串

文章目录 题目描述算法原理解法⼀:暴⼒求解(不会超时,可以通过)解法二:滑动窗口 代码实现解法⼀:暴⼒求解(时间复杂度为O(N^2^),空间复杂度为O(1))解法二:滑动窗口(时间复杂度为O(N)…

LeetCode-合并有序链表问题

合并两个有序链表 题目描述: 将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 思路: 首先建立一个头节点方便后续操作,然后开始循环将两个链表的节点值进行比较,如果list1节…

hbuiler中使用npm安装datav

注:datav边框样式目前使用时:适用于网页,不适用于app 1、先安装node 安装、配置Node路径 2、为Node配置环境变量 3、在hbuilder的设置中填写node的路径 配置 4、打开cmd输入npm install jiaminghi/data-view 安装dataV,&…

MicroSD 卡 使用读卡器 读取速度测试

设备 - - 电脑为m.2固态硬盘 usb口为USB3.2 gen2接口(即支持1GB/s的接口) cpu: amd3600 测试方案1 直接MicroSD卡放入读卡器测试 38MB/s 从sd卡复制到本地C盘 测试方案2 MicroSD卡使用闪迪的SD卡套套上之后一起插入读卡器 76MB/s 从sd卡复制到本地C盘

uni-app应用设置 可以根据手机屏幕旋转进行 (横/竖) 屏切换

首先 我们打开项目的 manifest.json 在左侧导航栏中找到 源码视图 然后找到 app-plus 配置 在下面加上 "orientation": [//竖屏正方向"portrait-primary",//竖屏反方向"portrait-secondary",//横屏正方向"landscape-primary",//横屏…

Mybatis核心配置文件加载流程详解

Mybatis核心配置文件加载流程详解 本文将介绍MyBatis在配置文件加载的过程中,如何加载核心配置文件、如何解析映射文件中的SQL语句以及每条SQL语句如何与映射接口的方法进行关联。 映射配置文件 在介绍核心配置文件加载流程前,先给出一个简单的MyBati…

ROS gazebo 机器人仿真,环境与robot建模,添加相机 lidar,控制robot运动

b站上有一个非常好的ros教程234仿真之URDF_link标签简介-机器人系统仿真_哔哩哔哩_bilibili,推荐去看原视频。 视频教程的相关文档见:6.7.1 机器人运动控制以及里程计信息显示 Autolabor-ROS机器人入门课程《ROS理论与实践》零基础教程 本文对视频教程…

Docker入门指南:从基础到实践

在当今软件开发领域,Docker已经成为一种不可或缺的工具。通过将应用程序及其依赖项打包成轻量级的容器,Docker实现了开发、测试和部署的高度一致性。本文将深入研究Docker的基本概念,并通过详细的示例代码演示如何应用这些概念于实际场景中。…

基于FPGA的视频接口之高速IO(光纤)

简介 对于高速IO口配置光纤,现在目前大部分开发板都有配置,且也有说明,在此根据自己的工作经验以及对于各开发板的说明归纳 通过高速IO接口,以及硬件配置,可以实现对于光纤的收发功能,由于GTX的速率在500Mbs到10Gbps之间,但通道高速io可配置光纤10G硬件,物理通完成,则…

掌握 Python sympy 库的高级计算技巧

更多资料获取 📚 个人网站:ipengtao.com Sympy是Python中一个强大的符号计算库,为数学和科学计算提供了丰富的功能。本文将深入介绍Sympy库的各项功能,并提供丰富的示例代码,以帮助大家更好地理解和应用这一工具。 S…

【论文精读】REACT: SYNERGIZING REASONING AND ACTING IN LANGUAGE MODELS

REACT: SYNERGIZING REASONING AND ACTING IN LANGUAGE MODELS 前言ABSTRACT1 INTRODUCTION2 REACT: SYNERGIZING REASONING ACTING3 KNOWLEDGE-INTENSIVE REASONING TASKS3.1 SETUP3.2 METHODS3.3 RESULTS AND OBSERVATIONS 4 DECISION MAKING TASKS5 RELATED WORK6 CONCLUSI…

SpringBoot整合ActiveMQ

SpringBoot整合ActiveMQ 文章目录 SpringBoot整合ActiveMQ下载与安装SpringBoot整合ActiveMQ导坐标改配置,默认的保存位置生产与消费消息实现监听类——实现消息自动消费监听器转发消息:流程性业务消息消费完转入下一个消息队列 下载与安装 https://act…

8、操作符重载

友元 可以通过friend关键字,把一个全局函数、另一个类的成员函数或者另一个类整体,声明为授权类的友元友元拥有访问授权类任何非公有成员的特权友元声明可以出现在授权类的公有、私有或者保护等任何区域且不受访问控制限定符的约束友元不是成员&#xf…

Qt + MySQL(简单的增删改查)

Qt编译MySql插件教程 帮助: SQL Programming QSqlDatabase 静态函数 1.drivers(),得到可以使用的数据库驱动名字的集合 [static] QStringList QSqlDatabase::drivers();2.addDatabase(),添加一个数据库实例 [static] QSqlDatabase QSql…

慢SQL诊断

最近经常遇到技术开发跑来问我慢SQL优化相关工作,所以干脆出几篇SQL相关优化技术月报,我这里就以公司mysql一致的5.7版本来说明下。 在企业中慢SQL问题进场会遇到,尤其像我们这种ERP行业。 成熟的公司企业都会有晚上的慢SQL监控和预警机制。…

Logstash输入Kafka输出Es配置

Logstash介绍 Logstash是一个开源的数据收集引擎,具有实时管道功能。它可以从各种数据源中动态地统一和标准化数据,并将其发送到你选择的目的地。Logstash的早期目标主要是用于收集日志,但现在的功能已经远远超出这个范围。任何事件类型都可…

FastAPI之响应模型

前言 响应模型我认为最主要的作用就是在自动化文档的显示时,可以直接给查看文档的小伙伴显示返回的数据格式。对于后端开发的伙伴来说,其编码的实际意义不大,但是为了可以不用再额外的提供文档,我们只需要添加一个 response_mod…

汽车服务行业分析:预计2028年将达到38亿元

在推进加快检验机构建设同时,综合评估检验机构数量、分布和检测能力,探索试点汽车 4S 店开展检验,提供维修、保养、车检一体化服务。汽车服务主要是指围绕汽车展开的一系列服务活动,包括维修、美容、金融等,除具有一般…

springboot3 liquibase SQL执行失败自动回滚,及自动打tag

一&#xff1a; 自动执行回滚&#xff0c; 已执行成功的忽略&#xff0c;新sql执行失败则执行新sql文件中的回滚sql pom.xml <dependency> <groupId>org.liquibase</groupId> <artifactId>liquibase-core</artifactId> <version>4.25.0&…