python精选22集(多任务、进程、进程池)

一.多任务介绍

  • 现实生活中

有很多的场景中的事情是同时进行的,比如开车的时候 手和脚共同来驾驶汽车,再比如唱歌跳舞也是同时进行的;
试想,如果把唱歌和跳舞这2件事情分开依次完成的话,估计就没有那么好的效果了

  • 程序中
    如下程序,来模拟“唱歌跳舞”这件事情
from time import sleep
def sing():
    for i in range(3):
        print("正在唱歌...%d"%i)
        sleep(1)

def dance():
    for i in range(3):
        print("正在跳舞...%d"%i)
        sleep(1)

if __name__ == '__main__':
    sing() #唱歌
    dance() #跳舞

在这里插入图片描述
很显然刚刚的程序并没有完成唱歌和跳舞同时进行的要求 如果想要实现“唱歌跳舞”同时进行,那么就需要一个新的方法,叫做:多任务

二.多任务概念

什么叫“多任务”呢?简单地说,就是操作系统可以同时运行多个任务。打个比方,你一边在用浏览器上网,一边在听MP3,一边在用Word赶作业,这就是多任务,至少同时有3个任务正在运行。还有很多任务悄悄地在后台同时运行着,只是桌面上没有显示而已。

1.意义

  • 充分利用计算机多核资源,提高程序的运行效率。

2.实现方案

  • 多进程 , 多线程

3.并行与并发

 并发 : 同时处理多个任务,内核在任务间不断的切换达到好像多个任务被同时执行的效果,实际每个时刻只有一个任务占有内核。
 并行 :多个任务利用计算机多核资源在同时执行,此时多个任务间为并行关系。

通俗理解将下图线程理解为任务即可
在这里插入图片描述

三.进程

1.定义

  • 程序在计算机中的一次运行。

    • 程序是一个可执行的文件,是静态的占有磁盘。
    • 进程是一个动态的过程描述,占有计算机运行资源,有一定的生命周期。

2.系统中如何产生一个进程

  • 1.用户空间通过调用程序接口或者命令发起请求
  • 2.操作系统接收用户请求,开始创建进程
  • 3.操作系统调配计算机资源,确定进程状态等
  • 4.操作系统将创建的进程提供给用户使用

3.基本概念

 cpu时间片:如果一个进程占有cpu内核则称这个进程在cpu时间片上。
PCB(进程控制块):在内存中开辟的一块空间,用于存放进程的基本信息,也用于系统查找识别进程。
进程ID(PID): 系统为每个进程分配的一个大于0的整数,作为进程ID。每个进程ID不重复。
  • Linux查看进程ID : ps -aux
S 等待态
R 执行态
D 等待态
T 等待态
Z 僵尸

<  有较高优先级
N  优先级较低
+  前台进程
s  会话组组长
l  有多线程的

* USER : 进程的创建者
* PID  :  操作系统分配给进程的编号,大于0的整数,系统中每个进程的PID都不重复。PID也是重要的区分进程的标志。
* %CPU,%MEM : 占有的CPU和内存
* STAT : 进程状态信息,S I 表示阻塞状态  ,R 表示就绪状态或者运行状态
* START : 进程启动时间
* COMMAND : 通过什么程序启动的进程

  • 父子进程 :

     系统中每一个进程(除了系统初始化进程)都有唯一的父进程,可以有0个或多个子进程。父子进程关系便于进程管理。
    
  • 查看进程树: pstree

4.进程状态

  • 三态

    	就绪态 : 进程具备执行条件,等待分配cpu资源
    
    	运行态 : 进程占有cpu时间片正在运行
    
    	等待态 : 进程暂时停止运行,让出cpu
    

在这里插入图片描述

  • 五态

    (在三态基础上增加新建和终止)

    新建 : 创建一个进程,获取资源的过程

    终止 : 进程结束,释放资源的过程

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值