python多任务异步协程

多任务异步协程,在爬虫里用的比较多

 多任务协程的的目的是程序有进行请求(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的单线程中个,这个执行效率很高

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值