python asyncio future 多线程_深究Python中的asyncio库-线程池
在同步線程中使用的run_in_executor就如它方法的名字所示,把協(xié)程放到了一個(gè)執(zhí)行器里面,可以在一個(gè)線程池,也可以在一個(gè)進(jìn)程池。另外還可以使用run_coroutine_threadsafe在其他線程執(zhí)行協(xié)程(這是線程安全的)。
多線程def?start_loop(loop):
asyncio.set_event_loop(loop)
loop.run_forever()
def?shutdown(loop):
loop.stop()
async?def?b1():
new_loop?=?asyncio.new_event_loop()
t?=?Thread(target=start_loop,?args=(new_loop,))
t.start()
future?=?asyncio.run_coroutine_threadsafe(a(),?new_loop)
print(future)
print(f'Result:?{future.result(timeout=2)}')
new_loop.call_soon_threadsafe(partial(shutdown,?new_loop))
In?:?await?b1()
Result:?A
這里面有幾個(gè)細(xì)節(jié)要注意:
協(xié)程應(yīng)該從另一個(gè)線程中調(diào)用,而非事件循環(huán)運(yùn)行所在線程,所以用asyncio.new_event_loop()新建一個(gè)事件循環(huán)
在執(zhí)行協(xié)程前要確保新創(chuàng)建的事件循環(huán)是運(yùn)行著的,所以需要用start_loop之類(lèi)的方式啟動(dòng)循環(huán)
接著就可以用asyncio.run_coroutine_threadsafe執(zhí)行協(xié)程a了,它返回了一個(gè)Future對(duì)象
可以通過(guò)輸出感受到future一開(kāi)始是pending的,因?yàn)閰f(xié)程a里面會(huì)sleep 1秒才返回結(jié)果
用future.result(timeout=2)就可以獲得結(jié)果,設(shè)置timeout的值要大于a協(xié)程執(zhí)行時(shí)間,要不然會(huì)拋出TimeoutError
一開(kāi)始我們創(chuàng)建的新的事件循環(huán)跑在一個(gè)線程里面,由于loop.run_forever會(huì)阻塞程序關(guān)閉,所以需要結(jié)束時(shí)殺掉線程,所以用call_soon_threadsafe回調(diào)函數(shù)shutdown去停止事件循環(huán)
這里再說(shuō)一下call_soon_threadsafe,看名字就知道它是線程安全版本的call_soon,其實(shí)就是在另外一個(gè)線程里面調(diào)度回調(diào)。BTW, 其實(shí)asyncio.run_coroutine_threadsafe底層也是用的它。
總結(jié)
以上是生活随笔為你收集整理的python asyncio future 多线程_深究Python中的asyncio库-线程池的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: sql 数组_sql注入中级
- 下一篇: lda主题词评论python_Pytho