
import asyncio
async def do_some_work(x):
print(x) loop = asyncio.get_event_loop()
coroutine1 = do_some_work('你好');
loop.run_until_complete(coroutine1)
loop = asyncio.get_event_loop()在一个函数入口( if name == "main":)的话,无论有多少次 loop.run_until_complete 这个项目在这块都是只有一个线程在工作吗,但是协程会有多个吗
1 chaleaoch Jan 4, 2021 协程使通过切换 code frame 实现伪并发的. loop = asyncio.get_event_loop() 这是不是阻塞调用啊? 所以一个线程如何启用多个 loop = asyncio.get_event_loop()? 我没太看懂你的意思. |
2 rqxiao OP async def do_some_work(x): print("waiting:", x) # await 后面就是调用耗时的操作 await asyncio.sleep(x) return "Done after {}s".format(x) while True: loop.run_until_complete(do_some_work(‘你好’)) 就是如果代码是这样的 ,也是在用一个线程吗 |
3 pursuer Jan 4, 2021 没有明确创建线程操作基本都是用的一个线程吧 |
4 wickyo Jan 4, 2021 get_event_loop 是一个线程中的 event_loop,run_until_complete 会等给定的协程对象完成后再结束,你这样是会有多个协程,但是都是同步的,如果是要协程并发可以用 gather import asyncio async def do_some_work(x): print(x) await asyncio.sleep(0.1) print('end') async def main(): coroutine1 = do_some_work(1) coroutine2 = do_some_work(2) await asyncio.gather( coroutine1, coroutine2 ) loop = asyncio.get_event_loop() loop.run_until_complete(main()) |
5 Vegetable Jan 4, 2021 是同一个 loop,没有明确重新创建前 loop 应该不会变 |
6 myCupOfTea Jan 4, 2021 run_until_complete 是会阻塞当前线程的,直到里面的 coroutine 跑完 |
7 canwushuang Jan 4, 2021 回到 pthon2 时代,当初叫 yield,如今封装成更好用的协程。针对有 io 延时的操作,通过挂起需要等待输出部分的代码而提速。还是单一线程,我的理解是“软”多线程吧。 |