您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關Python中asyncio庫-線程池是什么,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
在同步線程中使用的run_in_executor就如它方法的名字所示,把協程放到了一個執行器里面,可以在一個線程池,也可以在一個進程池。另外還可以使用run_coroutine_threadsafe在其他線程執行協程(這是線程安全的)。
多線程
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() <Future at 0x107edf4e0 state=pending> Result: A
這里面有幾個細節要注意:
協程應該從另一個線程中調用,而非事件循環運行所在線程,所以用asyncio.new_event_loop()新建一個事件循環
在執行協程前要確保新創建的事件循環是運行著的,所以需要用start_loop之類的方式啟動循環
接著就可以用asyncio.run_coroutine_threadsafe執行協程a了,它返回了一個Future對象
可以通過輸出感受到future一開始是pending的,因為協程a里面會sleep 1秒才返回結果
用future.result(timeout=2)就可以獲得結果,設置timeout的值要大于a協程執行時間,要不然會拋出TimeoutError
一開始我們創建的新的事件循環跑在一個線程里面,由于loop.run_forever會阻塞程序關閉,所以需要結束時殺掉線程,所以用call_soon_threadsafe回調函數shutdown去停止事件循環
這里再說一下call_soon_threadsafe,看名字就知道它是線程安全版本的call_soon,其實就是在另外一個線程里面調度回調。BTW, 其實asyncio.run_coroutine_threadsafe底層也是用的它。
關于Python中asyncio庫-線程池是什么就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。