python协程使用教程(对Python协程之异步同步的区别详解)
python协程使用教程
对Python协程之异步同步的区别详解一下代码通过协程、多线程、多进程的方式,运行代码展示异步与同步的区别。
|
import gevent import threading import multiprocessing # 这里展示同步和异步的性能区别,可以看到异步直接同时执行并完成, # 而同步,需要等待第一个完成后再次执行下一个,是有顺序的执行,而异步不需要 import time def task(pid): gevent.sleep( 0.5 ) print ( 'Task %s done' % pid) def task2(pid): time.sleep( 0.5 ) print ( 'Task %s done' % pid) def synchronous(): for i in range ( 1 , 10 ): task(i) def asynchronous(): threads = [gevent.spawn(task, i) for i in range ( 1 , 10 )] gevent.joinall(threads) def thread_chronous(): t_list = [] for i in range ( 1 , 10 ): t = threading.Thread(target = task2,args = (i,)) t.start() t_list.append(t) for j in t_list: j.join() def multi_chronous(): t_list = [] for i in range ( 1 , 10 ): t = multiprocessing.Process(target = task2, args = (i,)) t.start() t_list.append(t) for j in t_list: j.join() # 同步执行 print ( 'Synchronous:' ) synchronous() # 开启协程异步执行 自动切换函数 print ( 'Asynchronous:' ) asynchronous() # 开启线程异步执行 print ( 'Threading' ) thread_chronous() # 开启进程的异步执行 if __name__ = = '__main__' : print ( 'Multiprocess' ) multi_chronous() |
关于异步 同步的一些理解:
同步和异步的区别就在于是否等待IO执行的结果。好比你去麦当劳点餐,你说“来个汉堡”,服务员告诉你,对不起,汉堡要现做,需要等5分钟,于是你站在收银台前面等了5分钟,拿到汉堡再去逛商场,这是同步IO。
你说“来个汉堡”,服务员告诉你,汉堡需要等5分钟,你可以先去逛商场,等做好了,我们再通知你,这样你可以立刻去干别的事情(逛商场),这是异步IO。
老张爱喝茶,废话不说,煮开水。出场人物:老张,水壶两把(普通水壶,简称水壶;会响的水壶,简称响水壶)。
1 老张把水壶放到火上,立等水开。(同步阻塞)老张觉得自己有点傻
2 老张把水壶放到火上,去客厅看电视,时不时去厨房看看水开没有。(同步非阻塞)老张还是觉得自己有点傻,于是变高端了,买了把会响笛的那种水壶。水开之后,能大声发出嘀~~~~的噪音。
3 老张把响水壶放到火上,立等水开。(异步阻塞)老张觉得这样傻等意义不大
4 老张把响水壶放到火上,去客厅看电视,水壶响之前不再去看它了,响了再去拿壶。(异步非阻塞)老张觉得自己聪明了。所谓同步异步,只是对于水壶而言。普通水壶,同步;响水壶,异步。虽然都能干活,但响水壶可以在自己完工之后,提示老张水开了。这是普通水壶所不能及的。同步只能让调用者去轮询自己(情况2中),造成老张效率的低下。所谓阻塞非阻塞,仅仅对于老张而言。立等的老张,阻塞;看电视的老张,非阻塞。情况1和情况3中老张就是阻塞的,媳妇喊他都不知道。虽然3中响水壶是异步的,可对于立等的老张没有太大的意义。所以一般异步是配合非阻塞使用的,这样才能发挥异步的效用。
以上这篇对Python协程之异步同步的区别详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持开心学习网。
原文链接:https://blog.csdn.net/haeasringnar/article/details/79978718
- vscode如何配置python环境(VSCode Python开发环境配置的详细步骤)
- 多个图片拼接python实现(python实现两张图片的像素融合)
- python如何使用multiprocess(Python multiprocessing多进程原理与应用示例)
- python高德地图可视化(利用python和百度地图API实现数据地图标注的方法)
- pythonselenium怎么设置元素(Python2 Selenium元素定位的实现8种)
- 如何查看python是否安装selenium(selenium+python截图不成功的解决方法)
- python的静态方法和类方法(深入解析python中的实例方法、类方法和静态方法)
- opencv调用摄像头图像识别(Python+OpenCV采集本地摄像头的视频)
- pythonnumpy求行列式的值(Python numpy中矩阵的基本用法汇总)
- python中的迭代器详解(Python通过for循环理解迭代器和生成器实例详解)
- python第三方库的使用方法和作用(Python第三方库face_recognition在windows上的安装过程)
- 聊天室python小程序(用Python写一个模拟qq聊天小程序的代码实例)
- python中test函数用法(Python TestCase中的断言方法介绍)
- python读取txt文件每一行数据(python读取txt文件并取其某一列数据的示例)
- python全局变量设置(Python3.5局部变量与全局变量作用域实例分析)
- python pdf文件操作(Python常见读写文件操作实例总结文本、json、csv、pdf等)
- 包水饺(包水饺手法怎么包视频)
- 越南河粉(越南河粉来自哪里)
- 按这几方面养护佛肚竹盆景,保证枝叶繁茂,造型优美(按这几方面养护佛肚竹盆景)
- 冰岛旅游攻略(冰岛旅游攻略及花费八日游)
- 寒假旅游攻略(成都寒假旅游攻略)
- 菲律宾旅游攻略(菲律宾旅游攻略地图)
热门推荐
- html5发送文字特效(HTML5调用手机发短信和打电话功能)
- nginx配置静态资源访问(nginx 多个location转发任意请求或访问静态资源文件的实现)
- dede搜索模块下载(dede会员列表调用适用于企业、个人)
- 云主机属于什么层次的云服务(什么是云?什么是云服务?什么是云主机?)
- python八卦图(Python实现九宫格式的朋友圈功能内附“马云”朋友圈)
- django mysql设置(Django框架使用mysql视图操作示例)
- nginx https 域名配置(阿里云Nginx配置https实现域名访问项目图文教程)
- dedecms中如何设置推荐文章(实现dedecms友情链接分栏目调用的方法图)
- 查看docker日志大小(docker logs-查看docker容器日志的实现)
- CSS中margin和padding的区别
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9