asyncio中的task

本文探讨了在Python的asyncio库中如何取消任务。介绍了run_until_complete()和run_forever()两个方法的区别,前者在任务完成后会停止事件循环,而后者将持续运行直到手动停止。在遇到如数据库插入错误等异常情况时,需要停止后续任务,文章通过实例说明了协程间的交互和任务取消的处理方式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

取消asyncio中的task

run_until_complete()和run_forever()

run_until_complete() ,tasks运行完成时会停止loop,run_forever()则不会
在平时使用asyncio时遇到某些异常需要停止task,比如数据库插入表出错时出错需要停止后面task

import asyncio
import time


async def get_html(sleep_time):
    print("waiting")
    await asyncio.sleep(sleep_time)
    print(f"done after {sleep_time}s")


if __name__ == '__main__':
    loop = asyncio.get_event_loop()
    task1 = get_html(2)
    task2 = get_html(3)
    task3 = get_html(4)
    tasks = [task1, task2, task3]
    try:
        loop.run_until_complete(asyncio.gather(*tasks))
    except KeyboardInterrupt as e:  # 当在终端按下Ctrl+c时产生的异常 模拟异常产生时
        all_tasks = asyncio.Task.all_tasks()  # 获取所有tasks
        for task in all_tasks:
            print('cancel task')
            print(task.cancel())  # 取消task任务
        loop.stop()
        loop.run_forever() # run_forever没写的话可能会出现异常,可能与python版本有关
    finally:
        loop.close()

协程之间的调用

import asyncio

async def compute(x, y):
    print("Compute %s + %s ..." % (x, y))
    await asyncio.sleep(1.0)
    return x + y

async def print_sum(x, y):
    result = await compute(x, y)
    print("%s + %s = %s" % (x, y, result))

loop = asyncio.get_event_loop()
loop.run_until_complete(print_sum(1, 2))
loop.close()

下面时时序图
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值