importasyncioimporttimenow=lambda:time.time()asyncdefdo_some_work(x):print('Waiting:',x)awaitasyncio.sleep(x)return'Doneafter{}s'.format(x)asyncdefmain():coroutine1=do_some_work(1)coroutine2=do_some_work(2)coroutine3=do_some_work(4)tasks=[asyncio.ensure_future(coroutine1),asyncio.ensure_future(coroutine2),asyncio.ensure_future(coroutine3)]dones,pendings=awaitasyncio.wait(tasks)fortaskindones:print('Taskret:',task.result())start=now()loop=asyncio.get_event_loop()loop.run_until_complete(main())print('TIME:',now()-start)执行结果:Waiting:1Waiting:2Waiting:4(这里隔了四秒)Taskret:Doneafter1sTaskret:Doneafter2sTaskret:Doneafter4sTIME:4.007018804550171代码是网上复制的,不理解的是结果中那个停留了四秒。按小白的理解,执行到第一个awaitasyncio.sleep(x)的时候跳到第二个阻塞了又到第三个,然后第三个阻塞了不是应该跳回第一个吗?然后跳回函数内执行FRO循环。会先打印第一个出来然后两秒后再打印第二个,然后四秒后再打印第四个。上面的执行结果变成是等最后一个四秒结束后,一起for出来了。这里不理解?求大佬解惑
猛跑小猪
相关分类