首页 > 编程语言 > 详细

python之asyncio

时间:2019-04-01 14:38:26      阅读:135      评论:0      收藏:0      [点我收藏+]

asyncio是Python 3.4版本引入的标准库,直接内置了对异步IO的支持。

asnycio是用来编写并发代码的库,python3.5以后使用async/await语法。

asyncio 被用作多个提供高性能 Python 异步框架的基础,包括网络和网站服务,数据库连接库,分布式任务队列等等。

asyncio 往往是构建 IO 密集型和高层级 结构化 网络代码的最佳选择。

asyncio 提供一组 高层级 API 用于:

  • 并发地 运行 Python 协程 并对其执行过程实现完全控制;
  • 执行 网络 IO 和 IPC;
  • 控制 子进程;
  • 通过 队列 实现分布式任务;
  • 同步 并发代码;

此外,还有一些 低层级 API 以支持 库和框架的开发者 实现:

  • 创建和管理 事件循环,以提供异步 API 用于 网络化, 运行 子进程,处理 OS 信号 等等;
  • 使用 transports 实现高效率协议;
  • 通过 async/await 语法 桥接 基于回调的库和代码。

利用asyncio实现hello world                                                   

python3.4

import asyncio

@asyncio.coroutine
def hello():
    print("Hello!---")
    # 异步调用asyncio.sleep(1):
    r = yield from asyncio.sleep(1)
    print("---World!")

# 获取EventLoop:
loop = asyncio.get_event_loop()
# 执行coroutine
loop.run_until_complete(hello())
loop.close()

@asyncio.coroutine会把一个generator(生成器)标记为coroutine(协程)类型,然后我们就把这个coroutine扔到eventloop(事件循环)中去。

 

python之asyncio

原文:https://www.cnblogs.com/xiaozx/p/10636186.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!