www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁 > > 基礎(chǔ)實用電路
[導(dǎo)讀]全局解釋器鎖(Global Interpreter Lock)是計算機程序設(shè)計語言解釋器用于同步線程的一種機制,它使得任何時刻僅有一個線程在執(zhí)行。

全局解釋器鎖(Global Interpreter Lock)是計算機程序設(shè)計語言解釋器用于同步線程的一種機制,它使得任何時刻僅有一個線程在執(zhí)行。即便在多核處理器上,使用 GIL 的解釋器也只允許同一時間執(zhí)行一個線程,常見的使用 GIL 的解釋器有CPython與Ruby MRI??梢钥吹紾IL并不是Python獨有的特性,是解釋型語言處理多線程問題的一種機制而非語言特性。Python是一門解釋器語言,代碼通過解釋器執(zhí)行,Python存在多種解釋器,分別基于不同語言開發(fā),每個解釋器有不同的特點。CPython是主流版本的解釋器,這個解釋器是使用C語言編寫的,也是使用最為廣泛的解釋器,可以方便地和C/C++的類庫進(jìn)行交互,因此也是最受關(guān)注的解釋器。一種由java語言編寫的python解釋器,是將python編譯成Java字節(jié)碼然后執(zhí)行的一種解釋器,可以方便地和Java的類庫進(jìn)行交互。將Python代碼解釋為.Net平臺上運行的字節(jié)碼進(jìn)行執(zhí)行,類似Jython解釋器,可以方便的和.Net平臺上的類庫進(jìn)行交互。

Python 多線程(Multithreading)是一種編程技術(shù),允許在同一程序中同時執(zhí)行多個獨立的邏輯流,即線程。每個線程都有自己的程序計數(shù)器、??臻g和局部變量,它們共享同一進(jìn)程的全局變量、文件描述符和其他系統(tǒng)資源。線程是操作系統(tǒng)調(diào)度的基本單位,能夠在單個進(jìn)程中并發(fā)運行,從而實現(xiàn)任務(wù)的并行處理,提高程序的執(zhí)行效率和響應(yīng)速度。

概念要點:并發(fā)執(zhí)行:多線程允許程序的不同部分(即各個線程)同時(或近乎同時)執(zhí)行,給用戶帶來并行處理的感覺,即使在單核處理器上也能通過時間片輪轉(zhuǎn)實現(xiàn)并發(fā)。資源共享:同一進(jìn)程中的所有線程共享相同的內(nèi)存地址空間,包括全局變量、堆內(nèi)存等。這意味著線程之間可以直接讀寫共享數(shù)據(jù),但也可能導(dǎo)致競態(tài)條件、死鎖等同步問題,需要通過同步機制(如鎖、條件變量等)來協(xié)調(diào)對共享資源的訪問。輕量級進(jìn)程:相對于創(chuàng)建新進(jìn)程,創(chuàng)建線程的開銷較小,因為線程之間不需要復(fù)制整個地址空間。這使得線程成為處理大量并發(fā)任務(wù)或頻繁切換任務(wù)時的理想選擇。

全局解釋器鎖(GIL):在 CPython(Python 的標(biāo)準(zhǔn)實現(xiàn))中,有一個全局解釋器鎖(GIL),它限制了同一時刻只有一個線程能夠執(zhí)行 Python 字節(jié)碼。這意味著在多核 CPU 上,Python 線程并不能實現(xiàn)真正的并行計算。對于計算密集型任務(wù),通常建議使用多進(jìn)程或多線程與多進(jìn)程結(jié)合的方式來利用多核優(yōu)勢。

在交互效果上有所增強,但執(zhí)行過程和功能方面和CPython是一樣的。一種使用JIT(just-in-time)技術(shù)的編譯器,專注于執(zhí)行速度,對Python代碼進(jìn)行動態(tài)編譯,從而提高Python的執(zhí)行速度。PyPy在處理python代碼的過程中,一小部分功能的處理和CPython的執(zhí)行結(jié)果是有差異的,如果項目中要使用PyPy來進(jìn)行執(zhí)行效率的提升的話,一定要事先了解下PyPy和CPython的區(qū)別。

CPython的線程是操作系統(tǒng)的原生線程,在Linux的pthread完全由操作系統(tǒng)調(diào)度執(zhí)行。pthread本身不是線程安全的,需要使用者通過鎖來實現(xiàn)多線程的安全運行,因此CPython解釋器下的Python實現(xiàn)多線程也必然存在線程不安全的問題。這就為GIL在多核時代的使用埋下了隱患。Python是Guido van Rossum 在1989年發(fā)布的,那個時候計算機的主頻還沒有達(dá)到1G,程序全部都是運行在單核計算機上面,直到2005年多核處理器才被Intel開發(fā)出來。

戈登·摩爾 1965 年預(yù)測,每個集成電路的元件數(shù)量每 18 到 24 個月就會翻一倍,它的適用性預(yù)計會持續(xù)到 2015-2020 年。摩爾定律未失效前軟件系統(tǒng)可以單純借助硬件的進(jìn)步來獲得性能的提升或者只需少量改進(jìn),就可以坐享性能飛躍。然而從 2005 年開始,時鐘速率的增長和晶體管數(shù)量的增長已不再同步。由于處理器材料的物理性質(zhì)限制,時鐘速率已停止增長甚至下降,處理器制造商開始將更多執(zhí)行單元核心封裝到單個芯片中。這一趨勢給應(yīng)用程序開發(fā)和編程語言設(shè)計帶來越來越大的壓力。

程序員和編程語言決策者不得不考慮如何快速適應(yīng)多核硬件,來提高軟件性能和編程語言的市場占有率,Python也不例外受到?jīng)_擊。在單核時代,崇尚優(yōu)美、清晰、簡單的吉多.范羅蘇姆選擇在解釋器層面實現(xiàn)了一把全局互斥鎖,來保護(hù)Python對象從而實現(xiàn)對單核CPU的使用率,這種做法在單核時代很奏效。倘若在單核時未選擇GIL,那么開發(fā)者就需要自己實現(xiàn)任務(wù)的管理,這樣做對于CPU的利用率提高無法做到極致。

但是隨著多核時代的到來,高效地利用CPU 核心的有效方法就是使用并行性,多線程是充分實現(xiàn)并行的好方法,但是CPython的GIL卻阻礙了對多核CPU的利用。CPython的GIL給使用者帶來了便利,并且在GIL的基礎(chǔ)上開發(fā)了許多重要的Package和語言功能。但是多核CPU的普適和其他語言對Python的沖擊,讓GIL顯得原始而粗暴,無法有效利用多核處理器成為了弊端。

Python的多線程是通過 threading模塊 實現(xiàn)同一進(jìn)程內(nèi)的并發(fā)執(zhí)行流,適用于I/O密集型任務(wù)(如文件讀寫、網(wǎng)絡(luò)請求等),但受 GIL鎖 限制無法實現(xiàn)多核并行計算。 ??實現(xiàn)方式?:Python多線程本質(zhì)上是同一進(jìn)程內(nèi)的并發(fā)執(zhí)行,通過 CPython解釋器 的 GIL (Global Interpreter Lock)實現(xiàn),任何線程執(zhí)行前需先獲得鎖,執(zhí)行100條指令后自動釋放鎖,導(dǎo)致多線程無法同時運行。 ??適用場景?:適合文件處理、網(wǎng)絡(luò)通信等I/O密集型任務(wù),通過釋放GIL鎖實現(xiàn)非阻塞操作,提升程序響應(yīng)性。 ??局限性?:無法通過多線程有效利用多核CPU,實際運行效率受限于單核性能。?線程共享資源?:所有線程共享進(jìn)程的內(nèi)存空間和文件句柄,但每個線程擁有獨立的CPU寄存器上下文。 ?互斥鎖 (Mutex)?:用于保護(hù)共享資源,避免多個線程同時操作同一數(shù)據(jù)導(dǎo)致沖突。

隨著Python 3.11引入的plaintext復(fù)制threading模塊優(yōu)化,以及JIT編譯器的逐步普及,多線程在以下領(lǐng)域?qū)⒄宫F(xiàn)更大潛力:實時數(shù)據(jù)處理系統(tǒng),分布式微服務(wù)架構(gòu),機器學(xué)習(xí)流水線優(yōu)化,建議開發(fā)者結(jié)合具體業(yè)務(wù)場景,通過性能分析工具(如cProfile)持續(xù)優(yōu)化線程模型,充分發(fā)揮Python多線程在并發(fā)編程中的獨特優(yōu)勢。

?

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

室內(nèi)空氣質(zhì)量是工作場所健康、家庭舒適和工業(yè)安全的重要因素。監(jiān)測二氧化碳、顆粒物、溫度、濕度和其他環(huán)境指標(biāo)可以幫助預(yù)防健康問題,優(yōu)化暖通空調(diào)的使用,并保持符合建筑標(biāo)準(zhǔn)。在本教程中,我們將使用BleuIO USB加密狗和Hi...

關(guān)鍵字: BleuIO BLE傳感器 Python

內(nèi)存泄漏是Linux系統(tǒng)穩(wěn)定性的頭號殺手,傳統(tǒng)檢測方法依賴人工分析/proc/meminfo或valgrind,存在兩大痛點:1) 無法區(qū)分用戶態(tài)/內(nèi)核態(tài)泄漏;2) 缺乏實時定位能力。本文提出基于kmemleak+Pyt...

關(guān)鍵字: 內(nèi)存泄漏 kmemleak Python

利用這兩種趨勢,我們利用NVIDIA Jetson Nano開發(fā)了一種實時螺栓檢測和計數(shù)系統(tǒng)。該解決方案不僅涉及強大的機器學(xué)習(xí)模型的開發(fā),還涉及在Jetson Nano等邊緣設(shè)備上直接優(yōu)化和部署這些模型,從而實現(xiàn)工業(yè)過程...

關(guān)鍵字: Python TensorRT 實時螺栓檢測 機器學(xué)習(xí)

在自動化運維領(lǐng)域,Ansible憑借其簡單易用、無代理架構(gòu)等優(yōu)勢,成為了眾多企業(yè)的首選工具。然而,在實際運維過程中,不可避免地會遇到一些高危操作,如刪除重要文件、修改關(guān)鍵系統(tǒng)配置等。一旦這些操作執(zhí)行失敗或產(chǎn)生意外后果,可...

關(guān)鍵字: Ansible Python API封裝

起初,我考慮使用帶有Python的樹莓派。但后來我收到了ESP32S3 AI Cam模塊,它讓我思考:這個小板能處理整個工作嗎?

關(guān)鍵字: 人工智能 Python 樹莓派 ESP32S3

在測試測量領(lǐng)域,隨著儀器設(shè)備的多樣化發(fā)展,不同品牌、不同接口類型的儀器并存,給自動化測試系統(tǒng)的開發(fā)帶來了巨大挑戰(zhàn)。傳統(tǒng)方式下,針對每種儀器都需要編寫特定的控制代碼,不僅開發(fā)效率低下,而且維護(hù)成本高昂。Python作為一種...

關(guān)鍵字: Python PyVISA

本文檔探討了我們項目的不同階段,在MDEF碩士課程的IAAC Microchallenge II研討會期間開發(fā)的3D手繪畫布。這個項目一開始是一個簡單的想法,從我們過去的經(jīng)驗中產(chǎn)生的類似的切線(一個涉及使用手勢的2D繪圖...

關(guān)鍵字: 3D模型 存儲庫 Python

在現(xiàn)代電子設(shè)備的開發(fā)與維護(hù)過程中,對電源輸出電壓和電流的實時監(jiān)測至關(guān)重要。這不僅有助于確保設(shè)備穩(wěn)定運行,還能及時發(fā)現(xiàn)并解決潛在的電源管理問題。本文將介紹如何利用Python編寫腳本,通過串口通信從電源管理芯片獲取數(shù)據(jù),并...

關(guān)鍵字: Python 電源

推特是一個流行的在線新聞和社交媒體平臺,人們通過“推特”進(jìn)行互動。不僅是互動,還可以使用Twitter進(jìn)行促銷。而且,為了推廣,我們需要每分鐘、每小時、每一天或相應(yīng)的時間安排一條tweet。這個發(fā)微博的過程可以通過使用T...

關(guān)鍵字: 樹莓派 Twitter Bot Python

之前我們學(xué)習(xí)了使用樹莓派和OpenCV的人臉識別。今天我們就用這兩個來用python構(gòu)建一個車牌識別系統(tǒng)。實時車牌檢測和識別對于自動收費站,找出交通規(guī)則違規(guī)者以及解決其他與車輛相關(guān)的安全問題非常有用。

關(guān)鍵字: 車牌識別 樹莓派 Python
關(guān)閉