对Python协程之异步同步的区别详解


Posted in Python onFebruary 19, 2019

一下代码通过协程、多线程、多进程的方式,运行代码展示异步与同步的区别。

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协程之异步同步的区别详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python使用稀疏矩阵节省内存实例
Jun 27 Python
全面了解python字符串和字典
Jul 07 Python
python编程线性回归代码示例
Dec 07 Python
利用TensorFlow训练简单的二分类神经网络模型的方法
Mar 05 Python
python的格式化输出(format,%)实例详解
Jun 01 Python
Python并行分布式框架Celery详解
Oct 15 Python
对python3 sort sorted 函数的应用详解
Jun 27 Python
django 框架实现的用户注册、登录、退出功能示例
Nov 28 Python
利用python读取YUV文件 转RGB 8bit/10bit通用
Dec 09 Python
在Mac中PyCharm配置python Anaconda环境过程图解
Mar 11 Python
keras slice layer 层实现方式
Jun 11 Python
python 实现简单的计算器(gui界面)
Nov 11 Python
在python里从协程返回一个值的示例
Feb 19 #Python
Python3多线程基础知识点
Feb 19 #Python
Python进阶之全面解读高级特性之切片
Feb 19 #Python
在python里协程使用同步锁Lock的实例
Feb 19 #Python
对python 通过ssh访问数据库的实例详解
Feb 19 #Python
python 通过SSHTunnelForwarder隧道连接redis的方法
Feb 19 #Python
深入理解Django-Signals信号量
Feb 19 #Python
You might like
PHP filter_var() 函数 Filter 函数
2012/04/25 PHP
简单分析ucenter 会员同步登录通信原理
2014/08/25 PHP
php隐藏实际地址的文件下载方法
2015/04/18 PHP
PHP中set_include_path()函数相关用法分析
2016/07/18 PHP
弹出广告特效(一个IP只弹出一次)的代码
2007/07/27 Javascript
javascript基本包装类型介绍
2015/04/10 Javascript
javascript实现网页屏蔽Backspace事件,输入框不屏蔽
2015/07/21 Javascript
javascript实现九宫格相加数值相等
2020/05/28 Javascript
JS组件Bootstrap dropdown组件扩展hover事件
2016/04/17 Javascript
利用node.js爬取指定排名网站的JS引用库详解
2017/07/25 Javascript
详解利用 Express 托管静态文件的方法
2017/09/18 Javascript
vue router下的html5 history在iis服务器上的设置方法
2017/10/18 Javascript
JS代码实现电脑配置检测功能
2018/03/21 Javascript
Redux实现组合计数器的示例代码
2018/07/04 Javascript
使用Vue父子组件通信实现todolist的功能示例代码
2019/04/11 Javascript
html+jQuery实现拖动滑块图片拼图验证码插件【移动端适用】
2019/09/10 jQuery
[03:06]3分钟带你回顾DOTA2完美盛典&完美大师赛
2017/12/06 DOTA
Django中的“惰性翻译”方法的相关使用
2015/07/27 Python
Python模拟脉冲星伪信号频率实例代码
2018/01/03 Python
python pycurl验证basic和digest认证的方法
2018/05/02 Python
详解Django+Uwsgi+Nginx 实现生产环境部署
2018/11/06 Python
Django之Mode的外键自关联和引用未定义的Model方法
2018/12/15 Python
利用selenium爬虫抓取数据的基础教程
2019/06/10 Python
python实现可变变量名方法详解
2019/07/01 Python
在django项目中导出数据到excel文件并实现下载的功能
2020/03/13 Python
英国最大的海报商店:GB Posters
2018/03/20 全球购物
欧舒丹俄罗斯官方网站:L’OCCITANE俄罗斯
2019/11/22 全球购物
什么是事务?为什么需要事务?
2012/01/09 面试题
同学会邀请书大全
2014/01/12 职场文书
关于环保的演讲稿
2014/05/10 职场文书
篮球赛口号
2014/06/18 职场文书
企业贷款委托书格式
2014/09/12 职场文书
毕业生个人自荐书
2015/03/05 职场文书
初中班长竞选稿
2015/11/20 职场文书
2019运动会广播加油稿汇总
2019/08/21 职场文书
创业计划书之校园跑腿公司
2019/09/24 职场文书