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

news/2024/7/5 5:20:31

编写一个程序模拟进程

查看进程状态

修改代码后发现进程状态为由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://lihuaxi.xjx100.cn/news/1886863.html

相关文章

PO模式在selenium自动化测试框架有什么好处

PO模式是在UI自动化测试过程当中使用非常频繁的一种设计模式,使用这种模式后,可以有效的提升代码的复用能力,并且让自动化测试代码维护起来更加方便。 PO模式的全称叫page object model(POM),有时候叫做 p…

在线原型设计网站有哪些?这7个超好用!

如今,在线软件逐渐成为主流,网站原型设计工具也不例外。与桌面相比,在线原型工具具有独特的优势。都不需要安装、限制位置或限制操作系统。以下将为您推荐 7 款非常实用的在线原型设计工具。看看有没有你会喜欢的呢。 1、即时设计 即时设计是…

iframe 与主应用页面之间如何互相通信传递数据

背景 当我们的Web页面需要复用现有网站的页面时,我们通常会考虑代码层面的抽离引用,但是对于一些过于复杂的页面,通过 iframe 嵌套现有的网站页面也是一种不错的方式,。目前我就职的项目组就有多个业务利用 iframe 完成业务的复用…

Python-乒乓球小游戏【附完整源码】

乒乓球小游戏 乒乓球小游戏是一个简单而有趣的2D页面交互式游戏,玩家可以通过键盘输入来控制球拍上下移动来接球,从而体验乒乓球的乐趣。该游戏有单人和双人两种模式 运行效果: 一:主程序: import sys import cfg …

.Net中的集合

所有的集合都是继承自IEnumerable。集合总体可以分为以下几类:关联/非关联型集合,顺序/随机访问集合,顺序/无序集合,泛型/非泛型集合,线程集合。 各集合类底层接口关系图 泛型与非泛型集合类的分析 泛型集合是类型安…

三天精通Selenium Web 自动化 - 如何找到元素

1. 什么是元素? 元素:HTML 元素 2. 定位方式解析 Selenium WebDriver 提供一个先进的技术来定位 web 页面元素。Selenium 功能丰富的API 提供了多个定位策略如:Name、ID、CSS 选择器、XPath 等等,如下图所示: 一般会用ID来定位…

Spring和Spring Boot和Spring Cloud

Spring框架中的Bean注解: Component:这是一个通用的组件扫描标记,用于将类标记为Spring Bean。这使得Spring能够自动检测和管理这些类。通常与ComponentScan配合使用来指定需要扫描的包。 Service:这是Component的一个特殊变体&a…

Python三种方法实现topk问题(源码)

# topK问题 数组中有n个元素求前k个最大的数 # 1. 快排或小顶堆排n个数 返回前k个数 --- 时复为O(nnlog_2nk) # 2. 第一次优化:首先根据n数组建立一个大顶堆 每次获取arr[0](并将其移除) 原地移除的方法是将arr[0]与arr[-1]对调 后在arr[0:-1)时向下调整法 反复上…