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

2024-01-28 22:59

本文主要是介绍波奇学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指针。

进程的其他概念

竞争性:系统进程数目比较众多,cpu资源只有一个

独立性:多进程运行,独享各种资源,多进程运行期间互不干扰

并行:多个进程在多个cpu分别同时运行,称为并行

并发:多个进程在一个cpu下采用进程切换的方式,在一段时间内,让多个进程得以推进

进程切换:进程在CPU上离开时,要将上下文数据保存好,甚至带走

保存的目的

进程被切换的时候:保存上下文,恢复上下文

这篇关于波奇学Linux:Linux进程状态,进程优先级的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/655056

相关文章

linux-基础知识3

打包和压缩 zip 安装zip软件包 yum -y install zip unzip 压缩打包命令: zip -q -r -d -u 压缩包文件名 目录和文件名列表 -q:不显示命令执行过程-r:递归处理,打包各级子目录和文件-u:把文件增加/替换到压缩包中-d:从压缩包中删除指定的文件 解压:unzip 压缩包名 打包文件 把压缩包从服务器下载到本地 把压缩包上传到服务器(zip

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

hdu1565(状态压缩)

本人第一道ac的状态压缩dp,这题的数据非常水,很容易过 题意:在n*n的矩阵中选数字使得不存在任意两个数字相邻,求最大值 解题思路: 一、因为在1<<20中有很多状态是无效的,所以第一步是选择有效状态,存到cnt[]数组中 二、dp[i][j]表示到第i行的状态cnt[j]所能得到的最大值,状态转移方程dp[i][j] = max(dp[i][j],dp[i-1][k]) ,其中k满足c

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

Linux_kernel驱动开发11

一、改回nfs方式挂载根文件系统         在产品将要上线之前,需要制作不同类型格式的根文件系统         在产品研发阶段,我们还是需要使用nfs的方式挂载根文件系统         优点:可以直接在上位机中修改文件系统内容,延长EMMC的寿命         【1】重启上位机nfs服务         sudo service nfs-kernel-server resta

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念

状态dp总结

zoj 3631  N 个数中选若干数和(只能选一次)<=M 的最大值 const int Max_N = 38 ;int a[1<<16] , b[1<<16] , x[Max_N] , e[Max_N] ;void GetNum(int g[] , int n , int s[] , int &m){ int i , j , t ;m = 0 ;for(i = 0 ;

Linux服务器Java启动脚本

Linux服务器Java启动脚本 1、初版2、优化版本3、常用脚本仓库 本文章介绍了如何在Linux服务器上执行Java并启动jar包, 通常我们会使用nohup直接启动,但是还是需要手动停止然后再次启动, 那如何更优雅的在服务器上启动jar包呢,让我们一起探讨一下吧。 1、初版 第一个版本是常用的做法,直接使用nohup后台启动jar包, 并将日志输出到当前文件夹n