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)執(zhí)行結(jié)果:Waiting:1Waiting:2Waiting:4(這里隔了四秒)Taskret:Doneafter1sTaskret:Doneafter2sTaskret:Doneafter4sTIME:4.007018804550171代碼是網(wǎng)上復制的,不理解的是結(jié)果中那個停留了四秒。按小白的理解,執(zhí)行到第一個awaitasyncio.sleep(x)的時候跳到第二個阻塞了又到第三個,然后第三個阻塞了不是應該跳回第一個嗎?然后跳回函數(shù)內(nèi)執(zhí)行FRO循環(huán)。會先打印第一個出來然后兩秒后再打印第二個,然后四秒后再打印第四個。上面的執(zhí)行結(jié)果變成是等最后一個四秒結(jié)束后,一起for出來了。這里不理解?求大佬解惑
關于asyncio 執(zhí)行過程的問題。內(nèi)含代碼,對執(zhí)行順序有點不解
紫衣仙女
2019-05-22 16:03:49