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

Python線程池ThreadPoolExecutor使用方式

 更新時(shí)間:2024年02月10日 09:24:47   作者:AllardZhao  
這篇文章主要介紹了Python線程池ThreadPoolExecutor使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

如何使用線程池?    

實(shí)際案例

我們之前實(shí)現(xiàn)了一個(gè)多線程web視頻監(jiān)控服務(wù)器,我們需要對(duì)請(qǐng)求連接數(shù)做限制,以防止惡意用戶發(fā)起大量連接而導(dǎo)致服務(wù)器創(chuàng)建大量線程,最終因資源耗盡而癱瘓。

可以使用線程池,替代原來(lái)的每次請(qǐng)求創(chuàng)建線程。

解決方案

python3中有線程池實(shí)現(xiàn),使用標(biāo)準(zhǔn)庫(kù)中concurrent.futures下的ThreadPoolExecutor,對(duì)象的submit和map方法可以用來(lái)啟動(dòng)線程池中線程執(zhí)行任務(wù)。

線程池介紹:

線程池就是提前創(chuàng)建好某一固定數(shù)量的線程放到池子里面,需要使用的時(shí)候去這個(gè)池子中取一個(gè)線程出來(lái)讓它執(zhí)行任務(wù),執(zhí)行完以后再歸還給線程池以便后面的任務(wù)繼續(xù)使用線程。

代碼演示       

多線程池的簡(jiǎn)單使用

from concurrent.futures import ThreadPoolExecutor
 
# 創(chuàng)建Executor對(duì)象,指定線程池中線程數(shù)
executor = ThreadPoolExecutor(3)
 
 
# 使用線程池中線程執(zhí)行任務(wù)
# 定義任務(wù)函數(shù)a的b次方
def f(a, b):
    print('f', a, b)
    return a ** b
 
 
# 調(diào)用線程池中線程去執(zhí)行函數(shù)
future = executor.submit(f, 2, 3)
# 使用線程池中一個(gè)線程運(yùn)行這個(gè)函數(shù),這個(gè)函數(shù)運(yùn)行完以后
# 這個(gè)線程又會(huì)歸還到線程池中去
 
# 使用result得到函數(shù)的運(yùn)行結(jié)果
print(future.result())
# 如果函數(shù)的運(yùn)行事件比較長(zhǎng),在調(diào)用result的時(shí)候他還沒(méi)有執(zhí)行完,
# 這個(gè)result就會(huì)被阻塞到這里,直到這個(gè)函數(shù)運(yùn)行完
 
 
# 和python內(nèi)置的map方法類似,只不過(guò)他在多個(gè)線程上同時(shí)調(diào)用f
# 在第1個(gè)線程計(jì)算2的4次方,第2個(gè)線程計(jì)算3的5次方,第3個(gè)線程計(jì)算5的6次方
executor.map(f, [2, 3, 5], [4, 5, 6])
 
'''
假設(shè)當(dāng)前線程池中所有線程都在忙碌,一直在運(yùn)行函數(shù)并且沒(méi)有返回,
我們?cè)偬峤灰粋€(gè)任務(wù)的時(shí)候,就會(huì)出現(xiàn)pending,
等待線程池中有一個(gè)空閑線程來(lái)運(yùn)行它。
'''
import time
 
 
def f2(a, b):
    print('f2', a, b)
    time.sleep(10)
    # 等待10秒再返回
    return a ** b
 
 
# 運(yùn)行以下語(yǔ)句可以到,可以看到首先打印的'f2 2 4'、'f2 3 5'、'f2 5 6'
# 過(guò)了一會(huì)才把'f2 6 7'和'f2 7 8'打印出來(lái),直到前面退出了他才得到運(yùn)行權(quán)利
executor.map(f2, [2, 3, 5, 6, 7], [4, 5, 6, 7, 8])

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • python3使用matplotlib繪制散點(diǎn)圖

    python3使用matplotlib繪制散點(diǎn)圖

    這篇文章主要為大家詳細(xì)介紹了python3使用matplotlib繪制散點(diǎn)圖,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-03-03
  • python中常見(jiàn)錯(cuò)誤及解決方法

    python中常見(jiàn)錯(cuò)誤及解決方法

    在本篇內(nèi)容里小編給大家分享的是一篇關(guān)于python中常見(jiàn)錯(cuò)誤及解決方法的知識(shí)點(diǎn)內(nèi)容,需要的朋友們參考下。
    2020-06-06
  • 詳解Python列表賦值復(fù)制深拷貝及5種淺拷貝

    詳解Python列表賦值復(fù)制深拷貝及5種淺拷貝

    這篇文章主要介紹了Python列表賦值,復(fù)制,深拷貝以及5種淺拷貝詳解,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-05-05
  • 關(guān)于python中不同函數(shù)讀取圖片格式的區(qū)別淺析

    關(guān)于python中不同函數(shù)讀取圖片格式的區(qū)別淺析

    這篇文章主要給大家介紹了關(guān)于python中不同函數(shù)讀取圖片格式的區(qū)別,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2022-03-03
  • python使用json將字符串轉(zhuǎn)字典報(bào)錯(cuò)的解決

    python使用json將字符串轉(zhuǎn)字典報(bào)錯(cuò)的解決

    這篇文章主要介紹了python使用json將字符串轉(zhuǎn)字典報(bào)錯(cuò)的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • django 消息框架 message使用詳解

    django 消息框架 message使用詳解

    這篇文章主要介紹了django 消息框架 message使用詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-07-07
  • 利用Python實(shí)現(xiàn)自定義連點(diǎn)器

    利用Python實(shí)現(xiàn)自定義連點(diǎn)器

    這篇文章主要介紹了如何利用Python實(shí)現(xiàn)自定義連點(diǎn)器,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-08-08
  • Python優(yōu)化算法之遺傳算法案例代碼

    Python優(yōu)化算法之遺傳算法案例代碼

    優(yōu)化算法,尤其是啟發(fā)式的仿生智能算法在最近很火,它適用于解決管理學(xué),運(yùn)籌學(xué),統(tǒng)計(jì)學(xué)里面的一些優(yōu)化問(wèn)題,這篇文章主要介紹了Python優(yōu)化算法—遺傳算法,需要的朋友可以參考下
    2023-02-02
  • 簡(jiǎn)單介紹Python的Django框架加載模版的方式

    簡(jiǎn)單介紹Python的Django框架加載模版的方式

    這篇文章主要介紹了Python的Django框架加載模版的方式,包括一些對(duì)加載順序的介紹,需要的朋友可以參考下
    2015-07-07
  • Python的flask接收前臺(tái)的ajax的post數(shù)據(jù)和get數(shù)據(jù)的方法

    Python的flask接收前臺(tái)的ajax的post數(shù)據(jù)和get數(shù)據(jù)的方法

    這篇文章主要介紹了Python的flask接收前臺(tái)的ajax的post數(shù)據(jù)和get數(shù)據(jù)的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-04-04

最新評(píng)論