溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python中asyncio庫-線程池是什么

發(fā)布時間:2020-08-03 10:26:12 來源:億速云 閱讀:178 作者:清晨 欄目:編程語言

這篇文章將為大家詳細講解有關Python中asyncio庫-線程池是什么,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

在同步線程中使用的run_in_executor就如它方法的名字所示,把協(xié)程放到了一個執(zhí)行器里面,可以在一個線程池,也可以在一個進程池。另外還可以使用run_coroutine_threadsafe在其他線程執(zhí)行協(xié)程(這是線程安全的)。

Python中asyncio庫-線程池是什么

多線程

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

這里面有幾個細節(jié)要注意:

協(xié)程應該從另一個線程中調(diào)用,而非事件循環(huán)運行所在線程,所以用asyncio.new_event_loop()新建一個事件循環(huán)

在執(zhí)行協(xié)程前要確保新創(chuàng)建的事件循環(huán)是運行著的,所以需要用start_loop之類的方式啟動循環(huán)

接著就可以用asyncio.run_coroutine_threadsafe執(zhí)行協(xié)程a了,它返回了一個Future對象

可以通過輸出感受到future一開始是pending的,因為協(xié)程a里面會sleep 1秒才返回結果

用future.result(timeout=2)就可以獲得結果,設置timeout的值要大于a協(xié)程執(zhí)行時間,要不然會拋出TimeoutError

一開始我們創(chuàng)建的新的事件循環(huán)跑在一個線程里面,由于loop.run_forever會阻塞程序關閉,所以需要結束時殺掉線程,所以用call_soon_threadsafe回調(diào)函數(shù)shutdown去停止事件循環(huán)

這里再說一下call_soon_threadsafe,看名字就知道它是線程安全版本的call_soon,其實就是在另外一個線程里面調(diào)度回調(diào)。BTW, 其實asyncio.run_coroutine_threadsafe底層也是用的它。

關于Python中asyncio庫-線程池是什么就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

AI