
- Python 基礎
- Python - 首頁
- Python - 概述
- Python - 歷史
- Python - 特性
- Python vs C++
- Python - Hello World 程式
- Python - 應用領域
- Python - 直譯器
- Python - 環境搭建
- Python - 虛擬環境
- Python - 基本語法
- Python - 變數
- Python - 資料型別
- Python - 型別轉換
- Python - Unicode 系統
- Python - 字面量
- Python - 運算子
- Python - 算術運算子
- Python - 比較運算子
- Python - 賦值運算子
- Python - 邏輯運算子
- Python - 位運算子
- Python - 成員運算子
- Python - 身份運算子
- Python - 運算子優先順序
- Python - 註釋
- Python - 使用者輸入
- Python - 數字
- Python - 布林值
- Python 控制語句
- Python - 控制流
- Python - 決策
- Python - If 語句
- Python - If else
- Python - 巢狀 If
- Python - Match-Case 語句
- Python - 迴圈
- Python - for 迴圈
- Python - for-else 迴圈
- Python - While 迴圈
- Python - break 語句
- Python - continue 語句
- Python - pass 語句
- Python - 巢狀迴圈
- Python 函式 & 模組
- Python - 函式
- Python - 預設引數
- Python - 關鍵字引數
- Python - 僅關鍵字引數
- Python - 位置引數
- Python - 僅位置引數
- Python - 可變引數
- Python - 變數作用域
- Python - 函式註解
- Python - 模組
- Python - 內建函式
- Python 字串
- Python - 字串
- Python - 字串切片
- Python - 修改字串
- Python - 字串連線
- Python - 字串格式化
- Python - 跳脫字元
- Python - 字串方法
- Python - 字串練習
- Python 列表
- Python - 列表
- Python - 訪問列表元素
- Python - 修改列表元素
- Python - 新增列表元素
- Python - 刪除列表元素
- Python - 迴圈遍歷列表
- Python - 列表推導式
- Python - 排序列表
- Python - 複製列表
- Python - 合併列表
- Python - 列表方法
- Python - 列表練習
- Python 元組
- Python - 元組
- Python - 訪問元組元素
- Python - 更新元組
- Python - 解包元組
- Python - 迴圈遍歷元組
- Python - 合併元組
- Python - 元組方法
- Python - 元組練習
- Python 集合
- Python - 集合
- Python - 訪問集合元素
- Python - 新增集合元素
- Python - 刪除集合元素
- Python - 迴圈遍歷集合
- Python - 合併集合
- Python - 複製集合
- Python - 集合運算子
- Python - 集合方法
- Python - 集合練習
- Python 字典
- Python - 字典
- Python - 訪問字典元素
- Python - 修改字典元素
- Python - 新增字典元素
- Python - 刪除字典元素
- Python - 字典檢視物件
- Python - 迴圈遍歷字典
- Python - 複製字典
- Python - 巢狀字典
- Python - 字典方法
- Python - 字典練習
- Python 陣列
- Python - 陣列
- Python - 訪問陣列元素
- Python - 新增陣列元素
- Python - 刪除陣列元素
- Python - 迴圈遍歷陣列
- Python - 複製陣列
- Python - 反轉陣列
- Python - 排序陣列
- Python - 合併陣列
- Python - 陣列方法
- Python - 陣列練習
- Python 檔案處理
- Python - 檔案處理
- Python - 寫入檔案
- Python - 讀取檔案
- Python - 重新命名和刪除檔案
- Python - 目錄
- Python - 檔案方法
- Python - OS 檔案/目錄方法
- Python - OS 路徑方法
- 面向物件程式設計
- Python - OOPs 概念
- Python - 類 & 物件
- Python - 類屬性
- Python - 類方法
- Python - 靜態方法
- Python - 建構函式
- Python - 訪問修飾符
- Python - 繼承
- Python - 多型
- Python - 方法重寫
- Python - 方法過載
- Python - 動態繫結
- Python - 動態型別
- Python - 抽象
- Python - 封裝
- Python - 介面
- Python - 包
- Python - 內部類
- Python - 匿名類和物件
- Python - 單例類
- Python - 包裝器類
- Python - 列舉
- Python - 反射
- Python 錯誤 & 異常
- Python - 語法錯誤
- Python - 異常
- Python - try-except 塊
- Python - try-finally 塊
- Python - 丟擲異常
- Python - 異常鏈
- Python - 巢狀 try 塊
- Python - 使用者自定義異常
- Python - 日誌記錄
- Python - 斷言
- Python - 內建異常
- Python 多執行緒
- Python - 多執行緒
- Python - 執行緒生命週期
- Python - 建立執行緒
- Python - 啟動執行緒
- Python - 執行緒連線
- Python - 執行緒命名
- Python - 執行緒排程
- Python - 執行緒池
- Python - 主執行緒
- Python - 執行緒優先順序
- Python - 守護執行緒
- Python - 執行緒同步
- Python 同步
- Python - 執行緒間通訊
- Python - 執行緒死鎖
- Python - 中斷執行緒
- Python 網路程式設計
- Python - 網路程式設計
- Python - 套接字程式設計
- Python - URL 處理
- Python - 泛型
- Python 庫
- NumPy 教程
- Pandas 教程
- SciPy 教程
- Matplotlib 教程
- Django 教程
- OpenCV 教程
- Python 雜項
- Python - 日期 & 時間
- Python - 數學
- Python - 迭代器
- Python - 生成器
- Python - 閉包
- Python - 裝飾器
- Python - 遞迴
- Python - 正則表示式
- Python - PIP
- Python - 資料庫訪問
- Python - 弱引用
- Python - 序列化
- Python - 模板
- Python - 輸出格式化
- Python - 效能測量
- Python - 資料壓縮
- Python - CGI 程式設計
- Python - XML 處理
- Python - GUI 程式設計
- Python - 命令列引數
- Python - 文件字串
- Python - JSON
- Python - 傳送郵件
- Python - 擴充套件
- Python - 工具/實用程式
- Python - GUIs
- Python 高階概念
- Python - 抽象基類
- Python - 自定義異常
- Python - 高階函式
- Python - 物件內部
- Python - 記憶體管理
- Python - 元類
- Python - 使用元類進行超程式設計
- Python - 模擬和存根
- Python - 猴子補丁
- Python - 訊號處理
- Python - 型別提示
- Python - 自動化教程
- Python - Humanize 包
- Python - 上下文管理器
- Python - 協程
- Python - 描述符
- Python - 診斷和修復記憶體洩漏
- Python - 不可變資料結構
- Python 有用資源
- Python - 問答
- Python - 線上測驗
- Python - 快速指南
- Python - 參考
- Python - 速查表
- Python - 專案
- Python - 有用資源
- Python - 討論
- Python 編譯器
- NumPy 編譯器
- Matplotlib 編譯器
- SciPy 編譯器
Python - 執行緒池
執行緒池是一種自動高效管理多個執行緒的機制,允許併發執行任務。Python 沒有透過threading模組直接提供執行緒池。
相反,它透過multiprocessing.dummy模組和concurrent.futures模組提供基於執行緒的池化。這些模組提供了方便的介面來建立和管理執行緒池,使併發任務執行更容易。
什麼是執行緒池?
執行緒池是執行緒的集合,由一個池管理。池中的每個執行緒稱為工作執行緒或工作者執行緒。這些執行緒可以重複使用來執行多個任務,從而減少了重複建立和銷燬執行緒的負擔。
執行緒池控制執行緒的建立及其生命週期,使其能夠更有效地處理大量任務。
我們可以使用以下類在 Python 中實現執行緒池:
- Python ThreadPool 類
- Python ThreadPoolExecutor 類
使用 Python ThreadPool 類
multiprocessing.pool.ThreadPool類在multiprocessing模組中提供了一個執行緒池介面。它管理一個工作執行緒池,可以將作業提交到該池以進行併發執行。
ThreadPool物件透過處理工作執行緒之間的任務建立和分配來簡化多個執行緒的管理。它與最初為程序設計的Pool類共享一個介面,但已調整為也能與執行緒一起使用。
ThreadPool例項與Pool例項完全介面相容,應作為上下文管理器進行管理,或者手動呼叫close()和terminate()。
示例
此示例演示了使用Python執行緒池對數字列表並行執行square和cube函式,其中每個函式併發應用於數字,最多使用3個執行緒,每個執行緒在執行之間延遲1秒。
from multiprocessing.dummy import Pool as ThreadPool import time def square(number): sqr = number * number time.sleep(1) print("Number:{} Square:{}".format(number, sqr)) def cube(number): cub = number*number*number time.sleep(1) print("Number:{} Cube:{}".format(number, cub)) numbers = [1, 2, 3, 4, 5] pool = ThreadPool(3) pool.map(square, numbers) pool.map(cube, numbers) pool.close()
輸出
執行上述程式碼後,您將獲得以下輸出:
Number:2 Square:4 Number:1 Square:1 Number:3 Square:9 Number:4 Square:16 Number:5 Square:25 Number:1 Cube:1 Number:2 Cube:8 Number:3 Cube:27 Number:4 Cube:64 Number:5 Cube:125
使用 Python ThreadPoolExecutor 類
Pythonconcurrent.futures模組的ThreadPoolExecutor類提供了一個高階介面,用於使用執行緒非同步執行函式。concurrent.futures模組包括Future類和兩個Executor類:ThreadPoolExecutor和ProcessPoolExecutor。
Future 類
concurrent.futures.Future類負責處理任何可呼叫物件(例如函式)的非同步執行。要獲取Future物件,您應該在任何Executor物件上呼叫submit()方法。不應透過其建構函式直接建立它。
Future類中的重要方法有:
- result(timeout=None):此方法返回呼叫返回的值。如果呼叫尚未完成,則此方法將等待最多timeout秒。如果呼叫在timeout秒內未完成,則將引發TimeoutError。如果未指定timeout,則等待時間沒有限制。
- cancel():此方法嘗試取消呼叫。如果呼叫當前正在執行或已完成執行且無法取消,則該方法將返回布林值False。否則,呼叫將被取消,該方法返回True。
- cancelled():如果呼叫已成功取消,則返回True。
- running():如果呼叫當前正在執行且無法取消,則返回True。
- done():如果呼叫已成功取消或已完成執行,則返回True。
ThreadPoolExecutor 類
此類表示一個指定最大工作執行緒數的執行緒池,用於非同步執行呼叫。
concurrent.futures.ThreadPoolExecutor(max_threads)
示例
這是一個使用 concurrent.futures.ThreadPoolExecutor 類在 Python 中非同步管理和執行任務的示例。具體來說,它展示瞭如何將多個任務提交到執行緒池以及如何檢查它們的執行狀態。
from concurrent.futures import ThreadPoolExecutor from time import sleep def square(numbers): for val in numbers: ret = val*val sleep(1) print("Number:{} Square:{}".format(val, ret)) def cube(numbers): for val in numbers: ret = val*val*val sleep(1) print("Number:{} Cube:{}".format(val, ret)) if __name__ == '__main__': numbers = [1,2,3,4,5] executor = ThreadPoolExecutor(4) thread1 = executor.submit(square, (numbers)) thread2 = executor.submit(cube, (numbers)) print("Thread 1 executed ? :",thread1.done()) print("Thread 2 executed ? :",thread2.done()) sleep(2) print("Thread 1 executed ? :",thread1.done()) print("Thread 2 executed ? :",thread2.done())
它將產生以下輸出 -
Thread 1 executed ? : False Thread 2 executed ? : False Number:1 Square:1 Number:1 Cube:1 Thread 1 executed ? : False Thread 2 executed ? : False Number:2 Square:4 Number:2 Cube:8 Number:3 Square:9 Number:3 Cube:27 Number:4 Square:16 Number:4 Cube:64 Number:5 Square:25 Number:5 Cube:125