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

Python線程池ThreadPoolExecutor使用方式

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

如何使用線程池?    

實際案例

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

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

解決方案

python3中有線程池實現(xiàn),使用標準庫中concurrent.futures下的ThreadPoolExecutor,對象的submit和map方法可以用來啟動線程池中線程執(zhí)行任務。

線程池介紹:

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

代碼演示       

多線程池的簡單使用

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

總結(jié)

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

相關文章

  • python3使用matplotlib繪制散點圖

    python3使用matplotlib繪制散點圖

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

    python中常見錯誤及解決方法

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

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

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

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

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

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

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

    django 消息框架 message使用詳解

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

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

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

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

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

    簡單介紹Python的Django框架加載模版的方式

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

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

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

最新評論