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 2021-01-04 11:07:50 +08:00
协程使通过切换 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 2021-01-04 11:26:30 +08:00
没有明确创建线程操作基本都是用的一个线程吧
|
4
wickyo 2021-01-04 11:29:21 +08:00
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 2021-01-04 11:33:20 +08:00
是同一个 loop,没有明确重新创建前 loop 应该不会变
|
6
myCupOfTea 2021-01-04 16:46:54 +08:00
run_until_complete 是会阻塞当前线程的,直到里面的 coroutine 跑完
|
7
canwushuang 2021-01-04 22:35:58 +08:00
回到 python2 时代,当初叫 yield,如今封装成更好用的协程。针对有 io 延时的操作,通过挂起需要等待输出部分的代码而提速。还是单一线程,我的理解是“软”多线程吧。
|