多任务异步协程,在爬虫里用的比较多
多任务协程的的目的是程序有进行请求(request)等的io操作时,CPU有等待,使用协程提高CPU的利用率,让CPU不闲置
# 多任务协程的的目的是程序有进行请求(request,sleep,input)等的io操作时,CPU有等待,使用协程提高CPU的利用率,让CPU不闲置
import asyncio
import time
async def func1(): # 加上async表示这是一个协程函数
print('调用函数1')
await asyncio.sleep(2)
# 普通的time.sleep(3)是同步的,要现在这才是异步(睡眠时,其他函数可以直接运行,不用等该函数结束)
# await 理解为:挂起,自己一边睡觉去,让其他人函数可以介入
print('调用函数1')
async def func2():
print('我是函数2')
await asyncio.sleep(4)
print('我是函数2')
async def func3():
print('调用函数3')
await asyncio.sleep(3)
print('调用函数3')
async def main():
tasks= [ asyncio.create_task(func1()) , asyncio.create_task(func2()) , asyncio.create_task(func3()) ] # create_task创建协程对象,这里函数是有括号的哦~
await asyncio.wait(tasks) # 加上await才是异步操作,跟上面await asyncio.sleep()一样
if __name__ == '__main__':
t1 = time.time()
asyncio.run(main()) # 执行
t2 = time.time()
t3 = t2-t1
print('总耗时:',t3)
>>>
调用函数1
调用函数3
我是函数2
调用函数1
调用函数3
我是函数2
总耗时: 4.017297029495239
在python的单线程中个,这个执行效率很高