多任务编程

本文深入探讨了多任务编程的概念,包括多进程与多线程的原理,以及进程的创建流程、状态转换和资源分配策略。详细解析了进程控制块(PCB)的作用,以及Linux系统下进程状态标识符的意义,如D、S、T、R、Z等,并介绍了进程优先级调整的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

多任务编程

通过应用程序利用多个计算机核心达到多任务同时执行的目的,以此来提升程序执行效率

多进程,多线程

 

进程:程序在计算机中一次执行的过程

程序:是一个静态的描述,不占有计算机资源

进程:是一个动态的过程,占有cpu内存的计算机资源,有一定的生命周期

 

*同一个程序,每次执行都是不同的进程,因为分配的计算机资源不同

1、进程的创建流程

用户空间运行程序,发起进程创建申请-----》调用操作系统内核接口创建进程-----〉分配计算机资源,确定进程状态------》将新的进程提供给用户使用

2、多个进程,如何占用cpu

*一个内核同一时刻只能运行一个任务

*多个进程对内核资源进行争夺,操作系统决定哪个进程占有计算机核心

*占有计算机核心的进程我们称为该进程占有cpu的时间片

3、进程有哪些信息,如何保存

PCB(进程控制块:在*nix系统中进程创建后,会在内存开辟一块空间存放进程的相关信息,称为PCB)

信息:用户  PID    占有内存      优先级 等

MAC命令:ps aux

STAT表示进程状态

D:等待态(不可中断等待:不可被外界信号打断)

S:等待态(可中断等待:)

T:等待态(暂停)

R:运行态

Z:僵尸态

 

+:前台进程(不带+即为后台进程,后台进程基本都是系统进程)

< :高优先级

N:低优先级

l:有进程连接

s:会话组

 

 

PID:在操作系统中进程的唯一标志是大于0的整数,由系统自动分配

4、进程特征

*进程是操作系统资源分配的最小单位

*每个进程单独占有4G虚拟内存

*进程之间i相互独立,运行不受影响

 

进程的状态

三态

就绪态:进程具备运行条件,等待系统分配处理器运行

运行态:进程占有cpu,处于运行的状态

等待态:又称为阻塞态,睡眠状态,指进程暂时不具备运行的条件,需要阻塞等待(sleep、accept。。。。。)

 

五态

新建态:创建一个进程,获取资源,直接表现为运行一个程序,或者在程序中创建新的进程

终止态:进程结束进行,资源回收过程

 

 

进程优先级

优先级决定了一个进程的执行权限和占有资源的优先程度

top:动态查看当前运行的进程状态 q退出

 

linux中优先级范围     -20----------19

-20最高,用户程序默认优先级为0

 

nice:以指定的优先级运行程序

e.g.

nice     -9      ./while.py以9的优先级运行此程序

sudo nice --9 ./while.py 以-9的优先级运行此程序

renice:改变某个进程的优先级

renice     2     PID 

 

父子进程:在系统中除了初始化进程其他进程都有一个父进程,可能有多个子进程

进程树 pstree

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值