Python 协程的使用

本文介绍了Python中的异步IO机制,通过asyncio库实现,重点讨论了await关键字的作用,以及如何在协程中使用。文章通过烧水泡茶的例子解释了await如何让CPU在等待IO操作时切换到其他任务,提高执行效率。此外,还提到了asyncio.run和asyncio.wait()函数在管理协程任务中的应用。
摘要由CSDN通过智能技术生成

异步IO:就是发起一个IO操作(如:网络请求,文件读写等),这些操作一般是比较耗时的,不用等待它结束,可以继续做其他事情,结束时会发来通知。

协程:又称为微线程,在一个线程中执行,执行函数时可以随时中断,由程序(用户)自身控制,执行效率极高,与多线程比较,没有切换线程的开销和多线程锁机制。

python中异步IO操作是通过asyncio来实现的。

await

        await 的解释,认真看文字,逐步理解,你肯定能看懂这最通俗的解释

        await 就是把当前协程对象给挂起,暂时不管。await 后边一般放协程对象,但也可以放task或future对象

        举个例子,喝茶需要烧水,洗杯子,泡茶 ,烧水是需要时间的,await 烧水,就是等待水烧开,人就不管烧水这个事情,人可以去洗杯子。当水烧开了之后再接着烧开水的后一步。

        放到计算机里面,人就是cpu,烧水、洗杯子就是一个个协程函数,每当一个await 一个协程对象,cpu就切换出去,去完成其他的协程任务,等到该协程对象完成后,cpu在切回来,完成接下来的任务

import asyncio

async def func1():
    print(f'我是函数1')
    await asyncio.sleep(3)
    print(f'我就是函数1')  

async def func2():
    print(f'我是函数2')
    await asyncio.sleep(1)
    print(f'我就是函数2')  

        这里有两个协程对象,func1和func2,打印了【我是函数1】后,因为await了,cpu就切出去了,不管了该任务了,而是去完成其他协程任务,等待他自己暂停三秒后,cpu才会切回来再打印我就是函数1;注意有await,cpu切出去发现还有其他任务即func2,所以其打印了【我是函数2】,然后又await了,cpu又切出去了,但是没有其他任务了,此时过去了1秒,sleep(1)已经完成,cpu重新切回来,打印【我就是函数2】,又过去2秒,func1中的sleep(3)也完成了,cpu切回去func1,然后打印【我就是函数1】      

        执行大概的流程

        func1执行 -> print 我是函数1 -> await cpu切出去

        func2执行 -> print 我是函数2 -> await cpu切出去

        过了1秒

        asyncio.sleep(1)完成 -> cpu切回来func2 -> print  我就是函数2 

        过了2秒

        asyncio.sleep(3)完成 -> cpu切回来func1 -> print 我就是函数1

                

async.run

        async.run(),里面放的是一个协程对象。调用协程函数的方法,即开启该线程

asyncio.wait()

        其也是一个协程函数,返回一个协程对象。

        asyncio.wait(),里面放的是一个装着协程对象的列表

        帮助把所有多个协程任务进行封装处理,最后返回一个包含所有传入的协程任务的协程对象

一个简单的协程程序示例

import asyncio
import time

async def func1():
    print(f'我是函数1')
    await asyncio.sleep(3)
    print(f'我就是函数1')

async def func2():
    print(f'我是函数2')
    await asyncio.sleep(1)
    print(f'我就是函数2')

async def func3():
    print(f'我是函数3')
    await asyncio.sleep(2)
    print(f'我就是函数2')
    
async def main():
    tasks = [
        asyncio.create_task(func1),
        asyncio.create_task(func2),
        asyncio.create_task(func3),

    ]
    await asyncio.wait(tasks)
    
if __name__ == '__main__':
    start_time = time.time()
    asyncio.run(main())
    print(f'用时:{time.time()-start_time}')

        

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值