成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Python并發:線程和鎖

開發 后端
線程和鎖是硬件底層的軟件定義形式化,因此包含最簡單的可能并發模型。它構成了其他構建在其頂層的并發抽象基礎,因此理解這一點很重要。然而,直接在這些基礎上構建可靠,可擴展的系統是很困難的或著說是不可能的。

概述

線程和鎖是硬件底層的軟件定義形式化,因此包含最簡單的可能并發模型。它構成了其他構建在其頂層的并發抽象基礎,因此理解這一點很重要。然而,直接在這些基礎上構建可靠,可擴展的系統是很困難的或著說是不可能的。

[[262305]]

雖然大多數語言都支持線程和鎖,但CPython仍然使用全局解釋器鎖來防止線程同時訪問共享內存,因為CPython的內存管理是非線程安全的。雖然阻塞操作發生在GIL之外并且可能提高性能,但是線程切換所需的系統調用開銷可能會降低性能。這意味著Python中的線程主要用于I/O受限的場景,而不是CPU受限的場景。

說句題外話,我提到了CPython,因為Python規范的其他部分實現,例如Jython,沒有全局解釋器鎖。然而,這些實現在實踐中并沒有被廣泛使用,因為***:沒有人想要支持多Python實現,除非他們不得不這樣;第二:它們還不夠豐富;第三:由于需要原生支持C/C++擴展API,Python語言定義與C/C++緊密耦合,與其說是技術規范不如說是一個參考實現。

Python通過高級模塊threading模塊和低級模塊_thread直接支持線程。想要獲得更多有關這些模塊如何工作的信息,可以在線獲取源代碼。

入門

Python中典型的單線程“Hello World”執行非常簡單: 

Python并發:線程和鎖

多線程模擬并沒有太大的不同: 

Python并發:線程和鎖

基于我有限數量的測試,上面的腳本運行結果如下所示: 

Python并發:線程和鎖

我用了get_ident()打印“線程標識符”(一個魔法值,除了在運行時消除不同線程之間的歧義之外,沒有任何意義)。你可以看到在某些情況下,線程標識符是如何不同的,而在其他一些情況下,線程標識符又是相同的。相同的線程標識符并不意味著仍工作在同一個線程上,但如果工作不重疊并且不需要不同的線程標識符,Python會重新使用該標識符。

陷阱:時序性和一致性

如果你用threading.current_thread().getName()將線程標識符與線程名交換,你可能會獲得有序結果,很大的原因可能是因為每個線程使用相同的函數和源碼路徑,因此,每個線程之間的延遲差異是微不足道的,僅次于解釋器的延遲。然而,這并不意味著有序執行能夠得到保證;這是WikiBooks上“Python Programming”的一個例子,其中每個線程的創建和每個線程的執行具有明顯不同的時序性: 

Python并發:線程和鎖

以下結果是同一個樣本運行的輸出: 

Python并發:線程和鎖

這日志表示線程創建/執行是交錯的。由于增加功能的可變性增加,隨著線程創建和執行之間的時序越來越不一致,這些結果將變得越來越不可預測。但原理仍然是相同的;使用多個線程時無法保證一致的行為。

陷阱:訪問共享內存

當不同的線程訪問共享內存時,這可能導致不正確的行為。你可以擴展此示例以在使用多個線程進行計數時查看競爭條件:

Python并發:線程和鎖

這會在一次示例運行時生成如下輸出: 

Python并發:線程和鎖

此結果因創建的線程數而異,但你可以看到結果28與預期值100有多大區別。Counter().count是非線程安全的,在這里進行了演示(如果你有與我不同的機器,你可能會得到與28不同的結果)。如果遇到競爭條件,沒有足夠的日志記錄,可能很難找到相關的代碼部分。

陷阱:死鎖

當兩個代理嘗試獲取共享內存的相同區域時,最終就會發生死鎖。當在處理線程和鎖的低級抽象時,唯一的解決方案是確保每個代理有一種方法能正確地管理其鎖,或者具有鎖協調的整體規范。例如,用餐哲學問題強調了流程同步的重要性。Rosetta Code的用餐哲學python解決方案解決了這個同步問題:如果你(代理)不能及時獲取這兩個分叉,你可以釋放你已經擁有的任何叉子,以便另一個代理可以同時獲得這兩個叉子。

Python并發:線程和鎖

此方法不排除其他鎖定方法,像鎖定順序,或涉及流程同步的系統設計,像使用信號量的生產者-消費者模型,但在Python中可能不如在其他語言中普遍。

陷阱:異形方法和依賴關系

如果要在Python應用程序中應用多線程,那么你希望保證整個堆棧的正確性,你必須手動驗證核實線程安全性和依賴項的線程模型。有些為企業級多服務環境使用而設計的依賴項,例如redis,可以在設計階段首先考慮它們的并發模型(請參閱黑客新聞antirez關于多線程版本redis的評論)。有些依賴可能不會;使用boto2時,并行使用multiprocessing.pool.Pool從S3并行下載文件時,我可能遇到了死鎖,這需要重寫一個函數。因此,另一個依賴性的困難出現了;它們無法被同化,這意味著如果你在你的應用使用依賴模型之前沒有驗證所有將使用的依賴關系,那么在嘗試為特定用途添加依賴項時,你可能陷入項目的死胡同。

多線程日志記錄

如果你選擇使用Python中的原生線程模型,你可能會驚喜地發現logging模塊不僅是線程安全的,而且還支持從任何特定線程或進程進行日志記錄(示例在logging手冊)。然后,難點是在你的應用程序中哪里更可能觸發異常,這如何影響你的線程模型以及確保在這些代碼段周圍進行可靠的日志記錄。將日志添加到你的應用可能會產生不小的延遲,正如pylint通過警告模塊logging-lazy-interpolation通知你那樣,這也可能會給你的線程模型帶來困難。

concurrent.futures

在撰寫這篇文章時發現Python

multiprocessing.pool.ThreadPool實現從未被記錄或測試過,因為它從未完成,這讓我感覺非常不愉快。它在Python3.7中仍然還是這樣,因為它出現在GitHub鏡像的源代碼中。鑒于全局解釋器鎖的無所不在,以及未來并發程序主要是并行I/O相關的工作,使用Python3.x中提供的像concurrent.futures.Executor或類似的新異步模式可能更有意義,因為他們更全面。我沒有使用過這個模塊,但我想與multiprocessing相比,它不會產生顯著的性能損耗。

結論

Python對線程和鎖具有基本的支持,它可能不像其他語言(例如Java)中的線程和鎖那樣功能全面且有用。在使用像Python等更高級別的解釋語言進行操作時,***避免使用線程和鎖。然而,Python確實提供了關于線程和鎖定的足夠友好的曝光度,以便對線程和鎖的工作方式進行良好的學術練習,也給并發界提供了激動人心的介紹。

英文原文:https://bytes.yingw787.com/posts/2019/01/12/concurrency_with_python_threads_and_locks/

譯者:南宮云遙

責任編輯:武曉燕 來源: 今日頭條
相關推薦

2023-10-08 09:34:11

Java編程

2025-02-17 02:00:00

Monitor機制代碼

2016-11-23 16:08:24

Python處理器分布式系統

2025-01-10 07:10:00

2025-03-03 04:00:00

線程安全CPU

2023-09-26 10:30:57

Linux編程

2023-10-18 15:19:56

2013-05-30 00:49:36

C++11C++條件變量

2010-03-15 10:56:21

Python線程鎖

2017-11-17 15:57:09

Java多線程并發模型

2014-05-08 10:39:55

Python并發編程

2017-01-10 13:39:57

Python線程池進程池

2020-08-26 08:59:58

Linux線程互斥鎖

2024-10-29 15:23:45

Python線程安全

2023-07-05 08:18:54

Atomic類樂觀鎖悲觀鎖

2020-07-06 08:03:32

Java悲觀鎖樂觀鎖

2025-05-07 02:15:00

分布式鎖高并發UUID鎖

2013-07-31 11:09:05

C++11

2011-12-29 13:31:15

Java

2024-09-29 08:39:51

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品久久久久久福利一牛影视 | 日韩免费视频一区二区 | 欧美黄色一区 | 免费看91 | 午夜久久久久久久久久一区二区 | 一级片视频免费 | 国产高清美女一级a毛片久久w | 国产欧美精品一区二区三区 | 久久国产精品99久久久久 | 久久久国产精品视频 | 中文字字幕一区二区三区四区五区 | 亚洲免费人成在线视频观看 | 黄色国产大片 | 亚洲一区久久 | 日韩在线视频一区二区三区 | 亚洲精品乱 | 夜夜骑首页 | 蜜桃av人人夜夜澡人人爽 | 国产精品一区二区视频 | 亚洲成人一区 | 国产成人免费在线 | 欧美激情综合色综合啪啪五月 | 中文字幕专区 | 午夜免费福利片 | 国产中文字幕在线观看 | 久久小视频 | 自拍偷拍亚洲一区 | 99爱在线 | 成人九色 | 国产精品污www一区二区三区 | 欧美中文字幕一区二区 | 伊人网伊人网 | 日本成人在线播放 | 成人亚洲精品 | 欧美一区二区三区在线观看视频 | 亚洲黄色高清视频 | 欧美性久久久 | 高清久久久 | 日韩在线观看一区 | 天天干视频 | 亚洲成人av一区二区 |