
- 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 - GUI
- 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 中,當多個執行緒併發地操作共享資源時,同步它們的訪問以維護資料完整性和程式正確性非常重要。Python 中的執行緒同步可以透過使用 **threading** 模組提供的各種同步原語來實現,例如鎖、條件、訊號量和屏障,以控制對共享資源的訪問並協調多個執行緒的執行。
在本教程中,我們將學習 Python 的 **threading** 模組提供的各種同步原語。
使用鎖進行執行緒同步
Python 的 threading 模組中的鎖物件提供了最簡單的同步原語。它們允許執行緒在程式碼的關鍵部分獲取和釋放鎖,確保一次只有一個執行緒可以執行受保護的程式碼。
透過呼叫 **Lock()** 方法建立一個新的鎖,該方法返回一個鎖物件。可以使用 **acquire(blocking)** 方法獲取鎖,該方法強制執行緒同步執行。可選的 blocking 引數允許您控制執行緒是否等待獲取鎖,並使用 **release()** 方法釋放鎖。
示例
以下示例演示瞭如何在 Python 中使用鎖(threading.Lock() 方法)來同步執行緒,確保多個執行緒安全正確地訪問共享資源。
import threading counter = 10 def increment(theLock, N): global counter for i in range(N): theLock.acquire() counter += 1 theLock.release() lock = threading.Lock() t1 = threading.Thread(target=increment, args=[lock, 2]) t2 = threading.Thread(target=increment, args=[lock, 10]) t3 = threading.Thread(target=increment, args=[lock, 4]) t1.start() t2.start() t3.start() # Wait for all threads to complete for thread in (t1, t2, t3): thread.join() print("All threads have completed") print("The Final Counter Value:", counter)
輸出
執行上述程式碼時,會產生以下輸出:
All threads have completed The Final Counter Value: 26
用於同步 Python 執行緒的條件物件
條件變數允許執行緒等待,直到被另一個執行緒通知。它們對於提供執行緒之間的通訊非常有用。wait()方法用於阻塞一個執行緒,直到它被另一個執行緒透過notify()或notify_all()通知。
示例
此示例演示了Condition物件如何使用notify()和wait()方法來同步執行緒。
import threading counter = 0 # Consumer function def consumer(cv): global counter with cv: print("Consumer is waiting") cv.wait() # Wait until notified by increment print("Consumer has been notified. Current Counter value:", counter) # increment function def increment(cv, N): global counter with cv: print("increment is producing items") for i in range(1, N + 1): counter += i # Increment counter by i # Notify the consumer cv.notify() print("Increment has finished") # Create a Condition object cv = threading.Condition() # Create and start threads consumer_thread = threading.Thread(target=consumer, args=[cv]) increment_thread = threading.Thread(target=increment, args=[cv, 5]) consumer_thread.start() increment_thread.start() consumer_thread.join() increment_thread.join() print("The Final Counter Value:", counter)
輸出
執行上述程式後,將產生以下輸出:
Consumer is waiting increment is producing items Increment has finished Consumer has been notified. Current Counter value: 15 The Final Counter Value: 15
使用join()方法同步執行緒
Python的threading模組中的join()方法用於等待所有執行緒完成執行。這是一種同步主執行緒與其他執行緒完成的簡單方法。
示例
這演示了使用join()方法同步執行緒,以確保主執行緒在繼續執行之前等待所有啟動的執行緒完成其工作。
import threading import time class MyThread(threading.Thread): def __init__(self, threadID, name, counter): threading.Thread.__init__(self) self.threadID = threadID self.name = name self.counter = counter def run(self): print("Starting " + self.name) print_time(self.name, self.counter, 3) def print_time(threadName, delay, counter): while counter: time.sleep(delay) print("%s: %s" % (threadName, time.ctime(time.time()))) counter -= 1 threads = [] # Create new threads thread1 = MyThread(1, "Thread-1", 1) thread2 = MyThread(2, "Thread-2", 2) # Start the new Threads thread1.start() thread2.start() # Join the threads thread1.join() thread2.join() print("Exiting Main Thread")
輸出
執行上述程式後,將產生以下輸出:
Starting Thread-1 Starting Thread-2 Thread-1: Mon Jul 1 16:05:14 2024 Thread-2: Mon Jul 1 16:05:15 2024 Thread-1: Mon Jul 1 16:05:15 2024 Thread-1: Mon Jul 1 16:05:16 2024 Thread-2: Mon Jul 1 16:05:17 2024 Thread-2: Mon Jul 1 16:05:19 2024 Exiting Main Thread
其他同步原語
除了上述同步原語之外,Python的threading模組還提供:−
- RLocks(可重入鎖):鎖的一種變體,允許執行緒在釋放之前多次獲取相同的鎖,這在遞迴函式或巢狀函式呼叫中很有用。
- 訊號量:類似於鎖,但帶有一個計數器。執行緒可以獲取訊號量,直到初始化時定義的某個限制。訊號量對於限制對具有固定容量的資源的訪問很有用。
- 屏障:允許固定數量的執行緒在屏障點同步,並且只有在所有執行緒都到達該點後才能繼續執行。屏障對於協調必須全部完成某個執行階段才能繼續執行的執行緒組很有用。