python协程 async/await的理解

新老对比

用asyncio提供的@asyncio.coroutine可以把一个generator标记为coroutine类型,然后在coroutine内部用yield from调用另一个coroutine实现异步操作。为了简化并更好地标识异步IO,从Python 3.5开始引入了新的语法async和await,可以让coroutine的代码更简洁易读。请注意,async和await是针对coroutine的新语法,要使用新的语法,只需要做两步简单的替换:把@asyncio.coroutine替换为async;把yield from替换为await。

@asyncio.coroutine
def hello():
    print("Hello world!")
    r = yield from asyncio.sleep(1)
    print("Hello again!")
async def hello():
    print("Hello world!")
    r = await asyncio.sleep(1)
    print("Hello again!")

asyncio 和 EventLoop 的理解

asyncio是Python 3.4版本引入的标准库,直接内置了对异步IO的支持。
asyncio的编程模型就是一个消息循环。我们从asyncio模块中直接获取一个EventLoop的引用,然后把需要执行的协程扔到EventLoop中执行,就实现了异步IO。

消息循环机制

loop在很多框架模型都有,比如win的loop消息循环机制。安卓的主线程消息循环机制。

同样的EventLoop内部就是一个死循环,可以接收传入的协程任务并执行。

测试加入协程运行

直接运行协程任务报错:

async def async_hello():
    print("async Hello world!")
    r = await asyncio.sleep(1)
    print("async Hello again!")


if __name__ == '__main__':
    async_hello()

异常信息:

C:/Users/huruwo/Desktop/work/sanic_test/async_await_learn.py:25: RuntimeWarning: coroutine 'async_hello' was never awaited
  async_hello()
RuntimeWarning: Enable tracemalloc to get the object allocation traceback

必须使用await修饰才能调用

改为

if __name__ == '__main__':
    await async_hello()

还是报错

  File "C:/Users/huruwo/Desktop/work/sanic_test/async_await_learn.py", line 25
    await async_hello()
    ^
SyntaxError: 'await' out
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值