1.进程的概念

课本概念:程序的一个执行实例,正在执行的程序等。

内核观点:担当分配系统资源(CPU时间,内存)的实体。

其实:进程=内核的相关管理数据结构(task_struct、页表等)+程序的代码和数据

task_struct:是描述进程的结构体,是Linux内核的一种数据结构,它会被装载到RAM(内存)里并且包含着进程的信息。

task_struct内容分类:

1、标示符: 描述本进程的唯一标示符,用来区别其他进程。
2、状态: 任务状态,退出代码,退出信号等。
3、优先级: 相对于其他进程的优先级。
4、程序计数器: 程序中即将被执行的下一条指令的地址。
5、内存指针: 包括程序代码和进程相关数据的指针,还有和其他进程共享的内存块的指针
6、上下文数据: 进程执行时处理器的寄存器中的数据[休学例子,要加图CPU,寄存器]。
7、I/O状态信息: 包括显示的I/O请求,分配给进程的I/O设备和被进程使用的文件列表。
8、记账信息: 可能包括处理器时间总和,使用的时钟数总和,时间限制,记账号等。
9、...

2.进程标识符PID

如何查看进程属性:

可以用ps ajx,也可以ls /proc(proc是一个存放进程属性的文件)
例:
ps ajx | head -1 && ps ajx |grep myproc

ls /proc

我们写一个程序

然后使它运行

这时我们查询PID

如果我们关闭进程后再查询,则查不到该进程打印出的PID,因为proc是实时更新的

在程序内获取PID的方法:

#include<unistd.h> //头文件

getpid();//返回该进程的PID

getppid();//返回该进程的父进程的PID

输出结果

如何杀掉进程:

kill -9 +该进程的PID

我们写一个死循环的程序,持续打印PID

然后使用kill -9 命令关闭该进程

3.系统调用创建进程:fork命令初识

fork有两个返回值:
如果返回值为0,则为子进程;
返回值大于0,则为父进程;
父子进程代码共享,数据各自开辟空间,私有一份(采用写时拷贝)

让我们写个代码来更好的理解一下fork

运行起来

我们发现if和else if居然都运行了起来,并且在子进程中对val进行修改,父进程的val值并未改变

由此我们可以知道父子进程代码共享,且数据是独立的

4.进程状态

Linux进程状态本质就是用一个变量,取不同的值来表示;

linux进程有以下几个状态

R状态(运行状态)

一个进程已经准备就绪,可以随时被系统调度此时就是运行状态;

如果只要一个进程,cpu可以直接分配足够资源执行进程,但是,当有很多的进程被调度后,cpu的资源就不够分配 ,这时每个进程需要去竞争cpu资源,而cpu不可能同时给这么多进程分配资源;这时就要有一个运行队列(runqueue)把PCB组织起来;

进程在这个runqueue中,就是R状态

一个进程一旦持有cpu,会一直运行吗?

并不会
一个进程被拿到cpu执行时,并不是等这个进程执行完毕才切换下一个进程。
而是这多个进程在一个时间段内所有的进程都会执行(并发执行),
每个进程执行一个时间片的时间后,就会从cpu上拿下来,切换成下一个进程.(进程切换)
一个时间片通常是10ms左右

在查看进程状态时,我们会发现有x状态,也有x+状态,这是区分进程在前台执行还是在后台执行;

./process:进程在前台执行
./process &:进程在后台执行

S、D状态(休眠状态)

S状态:本质就是等待”资源“就绪,S状态可以中断;

D状态:也是一种休眠状态,不过D状态不可中断;

一个进程将1GB的数据放置到磁盘中,等待读取,我们知道外设读取速度是比较慢的,这时进程就会等待;但是在等待期间,OS内存严重不足(OS有权限来杀掉进程来释放空间的),这时如果OS看到这个等待的进程,把他杀掉,那么就会造成一个严重的问题:磁盘在读取数据时出现问题,这时它回去找调度它的进程,但是这时候发现进程没有了???就会造成这1GB数据的丢失。

如何避免这个问题?

给这个进程设置深度休眠状态,D状态,那么这个进程就不会被OS杀掉,就要等到进程自己醒来。注意D状态用kill也杀不掉,除非重启,有时要断电。

T、t状态

T状态:停止进程

t状态:遇到断点的暂停

kill -19 PID:暂停进程
kill -18 PID:继续进程

Z状态(僵尸进程)

Z状态:一个进程执行完毕,且进程也退出了,但是进程占用的资源并没有被完全释放。

让我们看下面的代码

将程序运行一段时间

子进程执行完后,父进程还在在执行

此时我们查询该进程的状态

子进程已经运行完毕,但是需要维持自己的退出信息,在自己进程的task_struct中会记录自己的退出信息,让父进程来读取,如果父进程没有读取,则该进程会一直存在。

孤儿进程

孤儿进程:父进程完成,而子进程还在执行;
孤儿进程一般由1号进程(OS本身)进行领养;

孤儿进程为什么要被OS领养?

要保证子进程被正常回收

X状态(死亡状态)

进程执行完毕,且所占用的资源全部释放;
kill -9 PID
killall 进程名

5.进程优先级

什么是优先级?

cpu资源分配的先后顺序,就是指进程的优先权(priority)。

本质是指定进程获取某种资源的先后顺序(一个或者多个简单数字)
task_struct进程控制块--->struct----->内部字段---->int prio=xxx
Linux中数字越小,优先级越高;

优先级与权限的区别

权限:能不能的问题
优先级:已经能了,获取资源的先后问题

为什么要有优先级?

进程访问的资源(cpu)始终都是有限的。
而系统中进程大部分情况都是比较多的,所以进程之间会有竞争,为了高效完成任务,更合理竞争相关资源,便具有了优先级。

Linux优先级的特点以及查看方式

PRI :代表这个进程可被执行的优先级,其值越小越早被执行

NI :代表这个进程的nice值

PRI:进程优先级

NI:进程优先级的修正数据,nice值;

新的优先级=优先级+nice值。从而达到对进程优先级动态修改的过程

注意:nice值是有范围的:[-20,19] -----40个数字,且优先级都是从80开始的;

如何修改进程的优先级?

1.top命令
2.进入top后按 'r' ,输入要修改进程的PID,在输入NI值;

Linux_进程理解、状态与优先级(详细版)的更多相关文章

  1. 2021蓝桥杯省赛C++A组试题E 回路计数 状态压缩DP详细版

    2021蓝桥杯省赛C++A组试题E 回路计数 状态压缩DP 题目描述 蓝桥学院由21栋教学楼组成,教学楼编号1到21.对于两栋教学楼a和b,当a和b互质时,a和b之间有一条走廊直接相连,两个方向皆可通 ...

  2. Android中进程生命周期的优先级

    “我们不是生产者,我只是大自然的搬运工.” 学习Android最好的途径当然是强大的官方文档了,其中在Processes and Threads一节中对于进程生命周期淘汰优先级,有着详细的介绍.原文如 ...

  3. MySQL与MariaDB核心特性比较详细版v1.0(覆盖mysql 8.0/mariadb 10.3,包括优化、功能及维护)

    注:本文严禁任何形式的转载,原文使用word编写,为了大家阅读方便,提供pdf版下载. MySQL与MariaDB主要特性比较详细版v1.0(不含HA).pdf 链接:https://pan.baid ...

  4. Linux_进程管理相关命令

    一.进程管理命令 1.ps -- 进程查看命令 1️⃣:ps(process state)命令用于列出当前的进程 2️⃣:可以显示详细的进程信息,包括: 用户识别符(UID),它确定进程的特权 唯一进 ...

  5. iOS App上架流程(2016详细版)

    iOS App上架流程(2016详细版) 原文地址:http://www.jianshu.com/p/b1b77d804254 感谢大神整理的这么详细 一.前言: 作为一名iOSer,把开发出来的Ap ...

  6. 手把手Maven搭建SpringMVC+Spring+MyBatis框架(超级详细版)

    手把手Maven搭建SpringMVC+Spring+MyBatis框架(超级详细版) SSM(Spring+SpringMVC+Mybatis),目前较为主流的企业级架构方案.标准的MVC设计模式, ...

  7. doc命令大全(详细版)

    doc命令大全(详细版) 1 echo 和 @回显命令@                        #关闭单行回显echo off                 #从下一行开始关闭回显@echo ...

  8. Operating System-Process(1)什么是进程&&进程的创建(Creation)&&进程的终止(Termination)&&进程的状态(State)

    本文阐述操作系统的核心概念之一:进程(Process),主要内容: 什么是进程 进程的创建(Creation) 进程的终止(Termination) 进程的状态(State) 一.什么是进程 1.1 ...

  9. linux下查看进程的状态 /proc/[pid]/status

    查看进程的状态: 1.查看进程的pid,以java为例:ps -ef | grep java 2.查看进程状态:cat /proc/[pid]/status 关键字: linux [root@loca ...

  10. linux0.11内核源码——进程各状态切换的跟踪

    准备工作 1.进程的状态有五种:新建(N),就绪或等待(J),睡眠或阻塞(W),运行(R),退出(E),其实还有个僵尸进程,这里先忽略 2.编写一个样本程序process.c,里面实现了一个函数 /* ...

随机推荐

  1. 【转载】sun的rpc ——rpcbind(nfs文件系统中的rpc)

    原文地址: https://blog.csdn.net/wangpeng138375/article/details/8169071 ================================= ...

  2. 面向分布式强化学习的经验回放框架——Reverb: A Framework for Experience Replay

    论文题目: Reverb: A Framework for Experience Replay 地址: https://arxiv.org/pdf/2102.04736.pdf 框架代码地址: htt ...

  3. git 如何在本地同步远程已经删除的分支

    背景 因为分支管理,release/*是被保护的,除非是已经合并到master才会被删除.所以这个时候本地存在已经删除的releas/*分支. 此时会发现,怎么都删除不了这些保护分支.留着也没意思,该 ...

  4. 利用 Amazon EMR Serverless、Amazon Athena、Apache Dolphinscheduler 以及本地 TiDB 和 HDFS 在混合部署环境中构建无服务器数据仓库(一)云上云下数据同步方案设计

    引言 在数据驱动的世界中,企业正在寻求可靠且高性能的解决方案来管理其不断增长的数据需求.本系列博客从一个重视数据安全和合规性的 B2C 金融科技客户的角度来讨论云上云下混合部署的情况下如何利用亚马逊云 ...

  5. Ruoyi-Cloud 启动失败的坑,关于 selectConfigList

    刚才编辑了一堆,不知道为啥加了个英文单词,当前页面刷新自动搜索了单词,之前的内容总的就是现在都要会SpringCloud,高并发,几个真正懂高并发的,问题一般项目也没有啥高并发.自己之前的项目遇到过高 ...

  6. ViT和MAE模型结合初探

    介绍 transfomer在NLP领域的应用已经非常广泛,但是在CV领域的应用还比较少,主要是因为CV领域的数据是二维的,而transfomer是基于序列的,因此需要将二维数据转换成序列数据,这就是V ...

  7. python学习(一)django orm多表查询

    ###多表查询 一般的多表查询都是直接建立一个多对多关系 class Books(models.Model): users = models.ManyToManyField(User, related ...

  8. MPTCP(一) :MPTCP概览

    MPTCP概览 参考链接 MPTCP官网 http://multipath-tcp.org/ MPTCP入门 https://access.redhat.com/documentation/zh-cn ...

  9. 全网最适合入门的面向对象编程教程:39 Python常用复合数据类型-集合

    全网最适合入门的面向对象编程教程:39 Python 常用复合数据类型-集合 摘要: 在 Python 中,集合(set)是一种常用的复合数据类型.集合是一组无序且不重复的元素.与列表和元组不同,集合 ...

  10. VMware 安装 OpenWrt

    准备 OpenWrt VMDK 固件映像 你可以直接下载 VMDK 版本的 OpenWrt 固件映像,或者自己构建一个,或者从 IMG 映像文件转换.一般来说 IMG 映像文件较为容易获取,因此下面介 ...