python异步编程案例之超时

asyncio.wait_for(aw,timeout,*,loop=None)
timeout可以是None也可以是一个float或int类型的数字,表示需要等待的秒数。如果timeout是None,则永不超时,一直阻塞到aw执行完毕。
如果达到timeout时间,将会取消待执行的任务,引发asyncio.TimeoutError。
如果想避免任务被取消,可以将其封装在shield()中。
如果await_for()被取消,aw也会被取消。
loop参数将在Python3.10中删除,所以不推荐使用。

import time
async def test():
    print(2)
    await asyncio.sleep(3)
    return 3
async def main():
    print(1)
    result = await test()
    print(result)
    print(4)
start = time.perf_counter()
# asyncio.run(main())
loop = asyncio.new_event_loop()
asyncio.set_event_loop(loop)
loop.run_until_complete(asyncio.wait([main(), main(), asyncio.wait_for(main(), timeout=1.0)]))
end = time.perf_counter()
print(end - start)
1
2
1
2
1
2
Task exception was never retrieved
3
4
3
4
3.002585000000181
future: <Task finished coro=<wait_for() done, defined at D:\anaconda3\envs\async\lib\asyncio\tasks.py:397> exception=TimeoutError()>
Traceback (most recent call last):
  File "D:\anaconda3\envs\async\lib\asyncio\tasks.py", line 449, in wait_for
    raise futures.TimeoutError()
concurrent.futures._base.TimeoutError
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值