关于Python中的asyncio库-asyncio简介与关键字

介绍

不懂关于Python中的asyncio库-asyncio简介与关键字?其实想解决这个问题也不难、下面让小编带着大家一起学习怎么去解决,希望大家阅读完这篇文章后大所收获。

官网非常推荐的一个实现高并发的一个模块是asyncio,在网络的高响应,高请求的场景下,高并发的实现越来越重要,Python也是在Python 3.4中引入了协程的概念,现在来好好学习下asyncio的原理和使用。

<强> 关于Python中的asyncio库-asyncio简介与关键字

<强> asyncio是干什么的?

异步网络操作

并发

协程

python3.0时代,标准库里的异步网络模块:选择(非常底层)python3.0时代,第三方异步网络库:龙卷风python3.4时代,asyncio:支持TCP、子进程

现在的asyncio,有了很多的模块已经在支持:aiohttp, aiodns, aioredis等等https://github.com/aio-libs这里列出了已经支持的内容,并在持续更新

当然到目前为止实现协程的不仅仅只有asyncio,龙卷风和gevent都实现了类似功能

<强>关于asyncio的一些关键字的说明:

event_loop事件循环:程序开启一个无限循环,把一些函数注册到事件循环上,当满足事件发生的时候,调用相应的协程函数

协同程序协程:协程对象,指一个使用异步关键字定义的函数,它的调用不会立即执行函数,而是会返回一个协程对象。协程对象需要注册到事件循环,由事件循环调用。

任务任务:一个协程对象就是一个原生可以挂起的函数,任务则是对协程进一步封装,其中包含了任务的各种状态

未来:代表将来执行或没有执行的任务的结果。它和任务上没有本质上的区别

异步/等待关键字:python3.5用于定义协程的关键字,异步定义一个协程,等待用于挂起阻塞的异步调用接口。

看了上面这些关键字,你可能扭头就走了,其实一开始了解和研究asyncio这个模块有种抵触,自己也不知道为啥,这也导致很长一段时间,这个模块自己也基本就没有关注和使用,但是随着工作上用Python遇到各种性能问题的时候,自己告诉自己还是要好好学习学习这个模块。

感谢你能够认真阅读完这篇文章,希望小编分享关于Python中的asyncio库-asyncio简介与关键字内容对大家有帮助,同时也希望大家多多支持,关注行业资讯频道,遇到问题就找,详细的解决方法等着你来学习!

关于Python中的asyncio库-asyncio简介与关键字