欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

淺談一下python線程池簡單應(yīng)用

 更新時間:2023年04月19日 10:15:49   作者:Heney33  
這篇文章主要介紹了淺談一下python線程池簡單應(yīng)用,線程池在系統(tǒng)啟動時即創(chuàng)建大量空閑的線程,程序只要將一個函數(shù)提交給線程池,線程池就會啟動一個空閑的線程來執(zhí)行它,需要的朋友可以參考下

一、線程池簡介

傳統(tǒng)多線程方案會使用“即時創(chuàng)建,即時銷毀”的策略。盡管與創(chuàng)建進(jìn)程相比,創(chuàng)建線程的時間已經(jīng)大大的縮短,但是如果提交給線程的任務(wù)時執(zhí)行時間較短,而且執(zhí)行次數(shù)及其頻繁,那么服務(wù)器將處于不停的創(chuàng)建線程,銷毀線程的狀態(tài)。

一個線程的運(yùn)行時間可以分為三部分:線程的啟動時間、線程體的運(yùn)行時間和線程的銷毀時間。

在多線程處理的情景中,如果線程不能被重用,就意味著每次線程運(yùn)行都要經(jīng)過啟動、銷毀和運(yùn)行3個過程。這必然會增加系統(tǒng)相應(yīng)的時間,減低了效率。

線程池在系統(tǒng)啟動時即創(chuàng)建大量空閑的線程,程序只要將一個函數(shù)提交給線程池,線程池就會啟動一個空閑的線程來執(zhí)行它。

當(dāng)該函數(shù)執(zhí)行結(jié)束后,該線程并不會死亡,而是再次返回到線程池中變成空閑狀態(tài),等待執(zhí)行下一個函數(shù),因此能夠避免多次創(chuàng)建線程,從而節(jié)省線程創(chuàng)建和銷毀的開銷,能帶來更好的性能和穩(wěn)定性。

此外,使用線程池可以有效地控制系統(tǒng)中并發(fā)線程的數(shù)量。當(dāng)系統(tǒng)中包含有大量的并發(fā)線程時,會導(dǎo)致系統(tǒng)性能急劇下降,甚至導(dǎo)致Python解釋器崩潰,而線程池的最大線程數(shù)參數(shù)可以控制系統(tǒng)中并發(fā)線程的數(shù)量不超過此數(shù)。

服務(wù)器CPU數(shù)有限,能夠同時并發(fā)的線程數(shù)有限,并不是開得越多越好,以及線程切換時有開銷的,如果線程切換過于頻繁,反而會使性能降低。

線程池適用于:突發(fā)性大量請求或需要大量線程完成任務(wù),但實際任務(wù)處理時間較短的場景

二、線程池在python中的應(yīng)用

從python3.2開始,標(biāo)準(zhǔn)庫提供了concurrent.futures模塊,它提供了兩個子類:ThreadPoolExecutor和ProcessPoolExecutor。其中ThreadPoolExecutor用于創(chuàng)建線程池,而ProcessPoolExecutor用于創(chuàng)建進(jìn)程池。不僅可以自動調(diào)度線程,還可以做到:

  • 主線程可以獲取某一個線程(或任務(wù))的狀態(tài),以及返回值
  • 當(dāng)一個線程完成的時候,主線程能夠立即知道
  • 讓多線程和多進(jìn)程編碼接口一致

使用線程池/進(jìn)程池來管理并發(fā)編程,只要將相應(yīng)的 task 函數(shù)提交給線程池/進(jìn)程池,剩下的事情就由線程池/進(jìn)程池來搞定。

ThreadPoolExecutor構(gòu)造函數(shù)有兩個參數(shù):

一個是max_workers參數(shù),用于指定線程池的最大線程數(shù),如果不指定的話則默認(rèn)是CPU核數(shù)的5倍。

另一個參數(shù)是thread_name_prefix,它用來指定線程池中線程的名稱前綴(可選),如下:

threadPool = ThreadPoolExecutor(max_workers=self.max_workers, thread_name_prefix="test_")

Exectuor 提供了如下常用方法:

方法描述
submit(fn, *args, **kwargs)將 fn 函數(shù)提交給線程池。*args 代表傳給 fn 函數(shù)的參數(shù),**kwargs 代表以關(guān)鍵字參數(shù)的形式為 fn 函數(shù)傳入?yún)?shù)
map(func,*iterables, timeout=None, chunksize=1)該函數(shù)類似于全局函數(shù) map(func, *iterables),只是該函數(shù)將會啟動多個線程,以異步方式立即對 iterables 執(zhí)行 map 處理
shutdown(wait=True)關(guān)閉線程池。wait=True,等待池內(nèi)所有任務(wù)執(zhí)行完畢回收完資源后才繼續(xù);wait=False,立即返回,并不會等待池內(nèi)的任務(wù)執(zhí)行完畢。但不管wait參數(shù)為何值,整個程序都會等到所有任務(wù)執(zhí)行完畢

程序?qū)?task 函數(shù)提交(submit)給線程池后,submit 方法會返回一個 Future 對象,F(xiàn)uture 類主要用于獲取線程任務(wù)函數(shù)的返回值。由于線程任務(wù)會在新線程中以異步方式執(zhí)行,因此線程執(zhí)行的函數(shù)相當(dāng)于一個“將來完成”的任務(wù),所以 Python 使用 Future 來代表。

Future 提供了如下方法:

方法描述
cancel()取消該 Future 代表的線程任務(wù)。如果該任務(wù)正在執(zhí)行,不可取消,則該方法返回 False;否則,程序會取消該任務(wù),并返回 True
cancelled()返回 Future 代表的線程任務(wù)是否被成功取消
running()如果該 Future 代表的線程任務(wù)正在執(zhí)行、不可被取消,該方法返回 True
done()如果該 Funture 代表的線程任務(wù)被成功取消或執(zhí)行完成,則該方法返回 True
result(timeout=None)獲取該 Future 代表的線程任務(wù)最后返回的結(jié)果。如果 Future 代表的線程任務(wù)還未完成,該方法將會阻塞當(dāng)前線程,其中 timeout 參數(shù)指定最多阻塞多少秒
exception(timeout=None)獲取該 Future 代表的線程任務(wù)所引發(fā)的異常。如果該任務(wù)成功完成,沒有異常,則該方法返回 None
add_done_callback(fn)為該 Future 代表的線程任務(wù)注冊一個“回調(diào)函數(shù)”,當(dāng)該任務(wù)成功完成時,程序會自動觸發(fā)該 fn 函數(shù)

線程池用完后,應(yīng)調(diào)用線程池的shutdown()方法,關(guān)閉線程池。也可使用with語句來管理線程池,可避免手動關(guān)閉線程池

示例一(使用submit方式):

from concurrent.futures import ThreadPoolExecutor # 導(dǎo)入ThreadPoolExecutor模塊
import time
 
max_workers = 5
t = []
t1 = time.time()
 
# 作為線程任務(wù)的函數(shù)
def task(x, y):
    return x + y
 
threadPool = ThreadPoolExecutor(max_workers)    # 創(chuàng)建最大線程數(shù)為max_workers的線程池
 
for i in range(20):     # 循環(huán)向線程池中提交task任務(wù)
    future = threadPool.submit(task, i, i+1)
    t.append(future)
 
# 若不需要獲取返回值,則可不需要下面兩行代碼
for i in t:
    print(i.result())   # 獲取每個任務(wù)的返回值,result()會阻塞主線程
 
threadPool.shutdown()   # 阻塞主線程,所有任務(wù)執(zhí)行完后關(guān)閉線程池
print(time.time() - t1)

示例二(使用map方式):

from concurrent.futures import ThreadPoolExecutor	# 導(dǎo)入ThreadPoolExecutor模塊
 
max_workers = 5
t = []
t1 = time.time()
 
# 作為線程任務(wù)的函數(shù)
def task(x):
    return x + (x + 1)
 
args = (0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19)
 
with ThreadPoolExecutor(max_workers) as threadPool:   # 創(chuàng)建最大線程數(shù)為max_workers的線程池
    results = threadPool.map(task, args)    # 啟動線程,并收集每個線任務(wù)的返回結(jié)果
 
    # 若無返回值,則可不需要下面兩行代碼
    for i in results:
        print(i)   

示例三:

as_complete():是一個生成器,在沒有任務(wù)完成的時候會阻塞,在有某個任務(wù)完成的時候會yield這個任務(wù),執(zhí)行語句,繼續(xù)阻塞,循環(huán)到所有任務(wù)結(jié)束,先完成的任務(wù)會先通知主線程

from concurrent.futures import ThreadPoolExecutor, as_completed
import time
 
max_workers = 5
t = []
t1 = time.time()
 
# 作為線程任務(wù)的函數(shù)
def task(x, y):
    return x + y
 
def handle_result(future):
    print(future.result())
 
with ThreadPoolExecutor(max_workers) as threadPool:    # 創(chuàng)建最大線程數(shù)為max_workers的線程池
 
    for i in range(20):     # 循環(huán)向線程池中提交task任務(wù)
        future = threadPool.submit(task, i, i+1)
        t.append(future)
 
    # 若不需要獲取返回值,則可不需要下面兩行代碼
    for future in as_completed(t):  # as_completed,哪個先完成就先處理哪個,會阻塞主線程,直到完成所有,除非設(shè)置timeout
        future.add_done_callback(handle_result)

到此這篇關(guān)于淺談一下python線程池簡單應(yīng)用的文章就介紹到這了,更多相關(guān)python線程池簡單應(yīng)用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • pytorch DataLoaderj基本使用方法詳解

    pytorch DataLoaderj基本使用方法詳解

    這篇文章主要為大家介紹了pytorch DataLoaderj基本使用方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • Python3 導(dǎo)入上級目錄中的模塊實例

    Python3 導(dǎo)入上級目錄中的模塊實例

    今天小編就為大家分享一篇Python3 導(dǎo)入上級目錄中的模塊實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-02-02
  • python使用pymongo操作mongo的完整步驟

    python使用pymongo操作mongo的完整步驟

    這篇文章主要給大家介紹了關(guān)于python使用pymongo操作mongo的完整步驟,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用python具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • Python for循環(huán)與getitem的關(guān)系詳解

    Python for循環(huán)與getitem的關(guān)系詳解

    這篇文章主要介紹了Python for循環(huán)與getitem的關(guān)系詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-01-01
  • Python批量修改文本文件內(nèi)容的方法

    Python批量修改文本文件內(nèi)容的方法

    這篇文章主要介紹了Python批量修改文本文件內(nèi)容的方法的相關(guān)資料,需要的朋友可以參考下
    2016-04-04
  • 解決pytorch 損失函數(shù)中輸入輸出不匹配的問題

    解決pytorch 損失函數(shù)中輸入輸出不匹配的問題

    這篇文章主要介紹了解決pytorch 損失函數(shù)中輸入輸出不匹配的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • 安裝Python和pygame及相應(yīng)的環(huán)境變量配置(圖文教程)

    安裝Python和pygame及相應(yīng)的環(huán)境變量配置(圖文教程)

    下面小編就為大家?guī)硪黄惭bPython和pygame及相應(yīng)的環(huán)境變量配置(圖文教程)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • 使用Python畫出小人發(fā)射愛心的代碼

    使用Python畫出小人發(fā)射愛心的代碼

    今天小編就為大家分享一篇使用Python畫出小人發(fā)射愛心的代碼,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • 深入理解Python內(nèi)置函數(shù)eval的使用

    深入理解Python內(nèi)置函數(shù)eval的使用

    在Python中,eval函數(shù)是一個內(nèi)置函數(shù),用于將字符串解析并執(zhí)行為Python表達(dá)式,本文將詳細(xì)介紹eval函數(shù)的使用方法和注意事項,需要的可以參考一下
    2023-06-06
  • Window10下python3.7 安裝與卸載教程圖解

    Window10下python3.7 安裝與卸載教程圖解

    本文通過圖文并茂的形式給大家介紹了WINDOW10下PYTHON3.7 安裝與卸載,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-09-09

最新評論