python中的异步处理属于比较高级的用法了,用来节省时间非常有用。传统的运行轨迹是阻塞的,就是一行代码必须完成了,然后才能运行下一行代码。异步运行就是我们现在有多个任务task1(2s)和task2(3s),用一个asyncio.gather(task1(), task2())函数对任务进行分配,那么这两个任务会同时进行,最终花费时间以task2的3s为准,而不是阻塞式的5s。
下面是一段完成上面示例的代码:
import asyncio
import timeasync def task1():await asyncio.sleep(2)async def task2():await asyncio.sleep(3)async def run_tasks():t1 = time.time()await asyncio.gather(task1(),task2())t2 = time.time()print(t2-t1)asyncio.run(run_tasks())
打印出来结果是3s。注意,一个是task1和task2里面要有await的任务,如果用time.sleep()是不行的因为time.sleep()不是个能异步运行的任务。第二个是要在.py脚本中运行,不能在notebook中运行。