多任务编程
通过应用程序利用多个计算机核心达到多任务同时执行的目的,以此来提升程序执行效率
多进程,多线程
进程:程序在计算机中一次执行的过程
程序:是一个静态的描述,不占有计算机资源
进程:是一个动态的过程,占有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