虽然有一些方法可以在Python中实现并行编程,但它默认是单线程语言。要充分利用单线程执行的优势,我们可以使用AsyncIO库。
异步代码顾名思义,AsyncIO在Python中提供了异步执行。异步代码以非阻塞的方式运行。如果一个函数等待时间较长,可以在等待期间执行另一个任务,而不是将所有任务都暂停。
下面的图像进一步说明了同步与异步代码执行的区别。在等待第一个响应时,我们可以发出第二个请求以更好地利用处理能力。
尽管它不使用多线程,但它确实执行代码的并发执行,并且在许多情况下大大减少了等待时间。
使用AsyncIOAsyncIO库有两个重要的关键字:
- async
- await 我们可以使用async def关键字来定义协程。 await关键字用在异步协程内,表示程序应该在此等待并同时执行其他操作。
看一下下面的代码示例:
import asyncio
async def co_routine(num):print('进入协程编号:', num)await asyncio.sleep(2)print('退出协程编号:', num)
async def main():await asyncio.gather(co_routine(1),co_routine(2),co_routine(3))
asyncio.run(main())以下是输出结果!进入协程编号:
1进入协程编号: 2进入协程编号: 3退出协程编号: 1退出协程编号: 2退出协程编号: 3正如您所见,我们在继续执行协程2和3之前,不需要等待协程1完成执行。
让我们逐步看一下代码。import asyncio这样导入asyncio库到您的Python代码中。async def co_routine(num):print('进入协程编号:', num)await asyncio.sleep(2)print('退出协程编号:', num)这是我们的异步协程。我们使用async def关键字来定义它。我们在进入时打印一条消息,然后协程休眠2秒。这里发生了魔法。await关键字表示我们必须等待,因此程序可以执行其他操作。await关键字只能在异步协程内使用!async def main():await asyncio.gather(co_routine(1),co_routine(2),co_routine(3))这定义了我们的异步主程序。asyncio.gather接受多个协程调用,并在它们并发执行后返回。这里,我们运行了值为1、2和3的协程。由于我们必须使用await关键字,所以我们的主程序也被定义为async。
但是,对于最终的调用,我们可以使用asyncio.run。asyncio.run(main())这将执行我们的主程序,而无需使用await。
现在,您可以在希望并发运行的程序中使用async/await。