详解python程序中的多任务


Posted in Python onSeptember 16, 2020

现实生活中,有很多场景中的事情是同时进行的,比如开车的时候,手和脚共同来驾驶汽车,再比如唱歌跳舞也是同时进行的。

以上这些可以理解为多任务。那在程序中怎么能做到多任务,它有什么好处?

接下来我们来看看没有多任务的程序是什么效果。

import time


def sing():
  for i in range(5):
    print("正在唱...")
    time.sleep(1)


def dance():
  for i in range(5):
    print("正在跳...")
    time.sleep(1)


def main():
  sing()
  dance()


if __name__ == "__main__":
  main()

运行结果:

详解python程序中的多任务

这个程序执行需要10秒钟,但是如果唱歌和跳舞能同时执行的话,只需要5秒钟就可以了。

没有多任务的时候,想一起执行上面的多个函数是做不到的,我们要学习的多任务就是多个函数(唱歌和跳舞)一起执行。

接下来我们来实现简单的多任务。

大家暂时不用关系代码怎么写,后续我们会具体讲解。

import time
import threading


def sing():
  for i in range(5):
    print("正在唱...")
    time.sleep(1)


def dance():
  for i in range(5):
    print("正在跳...")
    time.sleep(1)


def main():
  t1 = threading.Thread(target=sing)
  t2 = threading.Thread(target=dance)
  t1.start()
  t2.start()


if __name__ == "__main__":
  main()

运行结果:

详解python程序中的多任务

多任务的概念

什么叫“多任务”呢?简单地说,就是操作系统可以同时运行多个任务。

打个比方,你一边在用浏览器上网,一边在听MP3,一边在用 Word 赶作业,这就是多任务。

至少同时有3个任务正在运行,还有很多任务悄悄地在后台同时运行着,只是桌面上没有显示而已。

现在,多核 CPU 已经非常普及了,但是,即使过去的单核CPU,也可以执行多任务。

由于 CPU 执行代码都是顺序执行的,那么,单核CPU是怎么执行多任务的呢?

答案就是操作系统轮流让各个任务交替执行,任务1执行0.01秒,切换到任务2,任务2执行0.01秒,再切换到任务3,执行0.01秒……这样反复执行下去。

表面上看,每个任务都是交替执行的,但是,由于CPU的执行速度实在是太快了,我们感觉就像所有任务都在同时执行一样。

真正的并行执行多任务只能在多核 CPU 上实现,但是,由于任务数量远远多于 CPU 的核心数量,所以,操作系统也会自动把很多任务轮流调度到每个核心上执行。

那这里就引出了2个概念。

并发

指的是任务数多于 cpu 核数,通过操作系统的各种任务调度算法,实现多个任务“一起”执行。

多个进程指令被快速轮换执行,使得在宏观上具有多个进程同时执行的效果。

实际上总有一些任务不在执行,因为切换任务的速度相当快,看上去一起执行而已。

并行

指的是任务数小于等于 cpu 核数,在同一时刻有多条指令在多个处理器上真的同时执行。

多任务的好处

多任务可以简单地理解为同时执行多个不同程序,它有如下好处:

  • 可以把占据长时间的程序中的任务放到后台去处理。
  • 用户界面可以更加吸引人,比如用户点击了一个按钮去触发某些事件的处理,界面上可以弹出一个进度条来显示处理的进度。
  • 程序的运行速度可能加快。
  • 在一些等待的任务实现上如用户输入、文件读写和网络收发数据等,可以释放一些珍贵的资源如内存占用等等。

以上就是详解python程序中的多任务的详细内容,更多关于python 多任务的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
在Python中处理字符串之ljust()方法的使用简介
May 19 Python
Python部署web开发程序的几种方法
May 05 Python
使用XML库的方式,实现RPC通信的方法(推荐)
Jun 14 Python
Python基于回溯法子集树模板解决数字组合问题实例
Sep 02 Python
Python算法之图的遍历
Nov 16 Python
python处理数据,存进hive表的方法
Jul 04 Python
使用k8s部署Django项目的方法步骤
Jan 14 Python
Python docx库用法示例分析
Feb 16 Python
Django 开发环境与生产环境的区分详解
Jul 26 Python
python实现简单的购物程序代码实例
Mar 03 Python
如何在Python对Excel进行读取
Jun 04 Python
keras训练曲线,混淆矩阵,CNN层输出可视化实例
Jun 15 Python
python实现简单的tcp 文件下载
Sep 16 #Python
实现Python3数组旋转的3种算法实例
Sep 16 #Python
Python私有属性私有方法应用实例解析
Sep 15 #Python
PyQt5多线程防卡死和多窗口用法的实现
Sep 15 #Python
PyQt5结合matplotlib绘图的实现示例
Sep 15 #Python
pycharm激活方法到2099年(激活流程)
Sep 22 #Python
pycharm专业版远程登录服务器的详细教程
Sep 15 #Python
You might like
php桌面中心(二) 数据库写入
2007/03/11 PHP
深入理解PHP中的Streams工具
2015/07/03 PHP
PHP foreach遍历多维数组实现方式
2016/11/16 PHP
详解Yii2.0 rules验证规则集合
2017/03/21 PHP
Yii框架小部件(Widgets)用法实例详解
2020/05/15 PHP
getComputedStyle与currentStyle获取样式(style/class)
2013/03/19 Javascript
js禁止页面使用右键(简单示例代码)
2013/11/13 Javascript
JavaScript控制各种浏览器全屏模式的方法、属性和事件介绍
2014/04/03 Javascript
JavaScript forEach()遍历函数使用及介绍
2015/07/08 Javascript
JS中使用apply、bind实现为函数或者类传入动态个数的参数
2016/04/26 Javascript
node中使用es5/6以及支持性与性能对比
2017/08/11 Javascript
JS中Map和ForEach的区别
2018/02/05 Javascript
详解javascript appendChild()的完整功能
2018/08/18 Javascript
使用ThinkJs搭建微信中控服务的实现方法
2019/08/08 Javascript
Echarts地图添加引导线效果(labelLine)
2019/09/30 Javascript
搭建Vue从Vue-cli到router路由护卫的实现
2019/11/14 Javascript
JavaScript 链表定义与使用方法示例
2020/04/28 Javascript
vue3.0 自适应不同分辨率电脑的操作
2021/02/06 Vue.js
[02:05]2014DOTA2西雅图邀请赛 专访啸天mik夫妻档
2014/07/08 DOTA
[02:53]DOTA2亚洲邀请赛 NewBee战队巡礼
2015/02/03 DOTA
Python入门学习之字符串与比较运算符
2015/10/12 Python
python迭代器与生成器详解
2016/03/10 Python
numpy.ndarray 实现对特定行或列取值
2019/12/05 Python
python实现梯度下降法
2020/03/24 Python
前端canvas动画如何转成mp4视频的方法
2019/06/17 HTML / CSS
SQL面试题
2013/04/30 面试题
九年级体育教学反思
2014/01/23 职场文书
投资合作协议书
2014/04/17 职场文书
品酒会策划方案
2014/05/26 职场文书
小学爱国卫生月活动总结
2014/06/30 职场文书
计算机相关专业自荐信
2014/07/02 职场文书
社区党员群众路线教育实践活动心得体会
2014/11/03 职场文书
小学班主任工作总结2015
2015/04/07 职场文书
机关单位保密工作责任书
2015/05/11 职场文书
2017元旦、春节期间廉洁自律承诺书
2016/03/25 职场文书
vue使用echarts实现折线图
2022/03/21 Vue.js