协程asyncio_初识asyncio协程
初识asyncio协程
一、基本概念
要想了解学习协程相关知识要先对以下几个概念先行了解:
- 阻塞
- 阻塞状态是指程序未得到某所需计算资源时的挂起状态,简单说就是程序在等待某个操作未执行完前无法执行其他操作。
- 非阻塞
- 非阻塞状态是指在等待某项操作执行完前可以继续运行其他操作,也就是不会被阻塞。
- 同步
- 不同程序单元为了完成某项任务,在执行过程中以某种通信方式保证协调一致,假如有一个售票窗口,你必须等前面的人买完票,轮到你才能买,简言之同步意味着有序。
- 异步
- 不同程序单元为了完成某项任务,在执行过程中无需进行通信也能完成任务,例如爬虫,只要抓取目标url即可,无需关心其它抓取目标,简言之异步意味着无序。
- 并发
- 简单说就是操作系统在处理多个任务时快速切换,例如你在看电视时来电话了,此时你选择关闭电视,接完电话再打开看,这样的过程就是并发;
- 并行
- 简单说就是操作系统同时处理多个任务,例如你在看电视时来电话了,此时你选择边看电视边接电话,这样的过程就是并行。
- 协程
- 协程拥有自己的寄存器上下文和栈。协程调度切换时,将寄存器上下文和栈保存到其他地方,在切回来的时候,恢复先前保存的寄存器上下文和栈。因此协程能保留上一次调用时的状态,即所有局部状态的一个特定组合,每次过程重入时,就相当于进入上一次调用的状态。
二、asyncio 异步I/O
asyncio是用来编写并发代码的库,被用作多个提供高性能异步框架的基础,往往是构建I/O密集型和高层级结构化网络代码的最佳选择。
在了解asyncio的使用方法前,首先有必要先介绍一下,这几个贯穿始终的概念:
- event_loop事件循环:程序开启一个无限的事件循环,程序员会把一些函数注册到事件循环上。当满足事件发生的时候,调用相应的协程函数。
- coroutine协程:协程对象,指一个使用async关键字定义的函数,它的调用不会立即执行函数,而是会返回一个协程对象。协程对象需要注册到事件循环,由事件循环调用。
- task任务:一个协程对象就是一个原生可以挂起的函数,任务则是对协程进一步封装,其中包含任务的各种状态。
- future对象:代表将来执行或没有执行的任务的结果,与task没有本质上的区别。
- async/await关键字:python3.5 用于定义协程的关键字,async定义一个协程,await用于挂起阻塞的异步调用接口。
三、定义一个协程
干看概念总归是难以理解并记住的,下面动手来实现一个协程
from collection.abc import Coroutineasync def a(name): print('hello',name)if __name__ == '__main__': test = a('world') # 输出 hello world print(isinstance(test,Coroutine)) # 输出 True
通过以上的实例我们就完成了一个最简单的协程,可以发现其与普通函数不同的仅仅是在函数名前加了async
四、协程的工作流程
一个完整的协程工作流程如下:
- 定义/创建一个协程对象
- 将协程转为task任务
- 定义事件循环容器
- 将task任务放到事件循环容器触发
参照下面示例可以完整了解这个流程:
import asyncioasync def a(name): # 定义一个协程 print('hello',name)if __name__ == "__main__": coroutine = a('world') # 第一步,定义一个协程对象 task = asyncio.ensure_future(coroutine) # 第二步,将协程转换成task任务 loop = asyncio.get_event_loop() # 第三步,定义一个事件循环容器 loop.run_until_complete(task) # 第四步,将task任务放到事件循环容器
五、阻塞和await
在程序运行过程中遇到耗时的操作时会挂起该协程,转而执行别的协程,当挂起的协程运行完毕时再从别的协程切换回去,不等当前这个协程运没运行完毕。举个例子:假如有协程A和协程B,当协程A遇到阻塞耗时的操作时便转向运行协程B,当协程A的耗时操作结束再从协程B切换回去,不管协程B有没有运行完毕。
由前面asyncio的概念可以知道,使用await可以挂起一个协程。
import asyncioasync def a(name): await asyncio.sleep(3) # 模拟耗时的操作,不用time.sleep是因为time模块不支持异步 print('hello',name) if __name__ == "__main__": coroutine = a('world') loop = asyncio.get_event_loop() loop.run_until_complete(coroutine)
补充说明await后面的对象必须的格式:
- 原生协程(coroutine)对象
- 一个由types.coroutine()修饰的生成器
- 一个包含_await方法的对象返回的一个迭代器
- 简言之就是协程,任务,Future三种
总结:至此我们已经初步了解了什么是异步,什么是asyncio,以及协程的工作流程,并进行了实践。
协程asyncio_初识asyncio协程相关推荐
- 在 Android 开发中使用 Kotlin 协程 (一) -- 初识 Kotlin 协程
前言 最近在研究 Kotlin 协程,发现功能真的超级强大,很有用,而且很好学,如果你正在或计划使用 Kotlin 开发 Android,那么 Kotlin 协程你一定不能错过! 协程是什么? 我们平 ...
- Python Module — asyncio 协程并发
目录 文章目录 目录 Python Co-routines Asyncio Module Event Loop Async 与 Await async def async for async with ...
- python3 asyncio 协程模块
一直对asyncio这个库比较感兴趣,毕竟这是官网也非常推荐的一个实现高并发的一个模块,python也是在python 3.4中引入了协程的概念.也通过这次整理更加深刻理解这个模块的使用 asynci ...
- 10-异步爬虫(线程池/asyncio协程)实战案例
异步爬虫: 基于线程池 基于单线程+多任务的异步爬虫 线程池 from multiprocessing.dummy import Pool map(callback,alist) 可以使用callba ...
- asyncio协程与并发
并发编程 Python的并发实现有三种方法. 多线程 多进程 协程(生成器) 基本概念 串行:同时只能执行单个任务 并行:同时执行多个任务 在Python中,虽然严格说来多线程与协程都是串行的,但其效 ...
- c++ 协程_理解Python协程(Coroutine)
由于GIL的存在,导致Python多线程性能甚至比单线程更糟. GIL: 全局解释器锁(英语:Global Interpreter Lock,缩写GIL),是计算机程序设计语言解释器用于同步线程的一种 ...
- python协程与多线程比较_python-协程、多线程、多进程性能比较
基本概念 进程:进程是一个具有独立功能的程序关于某个数据集合的一次运行活动.进程是操作系统动态执行的基本单元. 线程:一个进程中包含若干线程,当然至少有一个线程,线程可以利用进程所拥有的资源.线程是独 ...
- linux的进程/线程/协程系列5:协程的发展复兴与实现现状
协程的发展复兴与实现现状 前言 本篇摘要: 1. 协同制的发展史 1.1 协同工作制的提出 1.2 自顶向下,无需协同 1.3 协同式思想的应用 2. 协程的复兴 2.1 高并发带来的问题 2.2 制 ...
- python协程详解_python协程详解
原博文 2019-10-25 10:07 − # python协程详解 ![python协程详解](https://pic2.zhimg.com/50/v2-9f3e2152b616e89fbad86 ...
最新文章
- 15瓶饮料4个空瓶换一瓶_2021江苏公务员考试行测技巧:你会用“空瓶”换水吗?...
- java 升级1.8_升级系统中的java到1.8版本详解
- 渣渣小本求职复习之路每天一博客系列——TCP/IP协议栈(5)
- python3 多线程_python3--多线程的使用
- 豆瓣9.0,35万读者“搜不到信息”的神秘作者,我们帮你找到了
- robotframework自动化测试修炼宝典_自动化测试之框架Cucumber和RobotFramework的实战对比...
- 【距离GDOI:128天】【POJ2778】DNA Sequence(AC自动机+矩阵加速)
- 前端遇到瓶颈了怎么办?
- LeetCode每日一题: 搜索插入位置(No.35)
- 定时任务@Scheduled(cron = “* * * * * *?“) 表达式详解
- flash遮罩动画的使用技巧
- .net视频觉得做得最好的是天轰穿
- 服务器搭建说明以及接口调用文档
- 学校做计算机教室锐捷,锐捷“云课堂”:先改变桌面云,再改变教室
- 卡尔滤波算法 java_卡尔曼滤波算法及其代码
- 检验新买内存条的真假
- 用计算机计算根号2^2-1÷,2根号2(万能计算器在线使用)
- 面向对象;构造函数;原型对象
- understand学习
- 【React】解决antd样式没有显示问题(网页频闪问题)
热门文章
- 数据中心安全风控_平安银行Hadoop集群跨数据中心迁移项目告捷项目骨干专访
- python连接不上数据库_详解pycharm连接不上mysql数据库的解决办法
- Consecutive Factors (20)
- N皇后问题(暴力法、回溯法)
- java迭代器_74.Java迭代器
- 以下哪些参数不是sqlmap中的_变频器控制中必须要设置哪些参数?
- 内蒙古全国计算机考试注意事项,2018年3月内蒙古自治区呼和浩特计算机等级考试注意事项...
- ubuntu安装python_常用linux指令 ubuntu环境pytorch配置
- C++之继承探究(十二):子类的构造、析构和赋值运算符重载
- 输入为数字和大写_表格中如何录入分数、邮政编码、大写数字?