日韩欧乱色一区二区三区在线_久久―日本道色综合久久_欧美日本一区二区_网曝91综合精品门事件在线

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁  >  技術(shù)干貨  > 什么是Python全局解釋器鎖GIL(Global Interpreter Lock)?

什么是Python全局解釋器鎖GIL(Global Interpreter Lock)?

來源:千鋒教育
發(fā)布人:xqq
時(shí)間: 2023-10-11 15:38:58 1697009938

一、Python全局解釋器鎖GIL(Global Interpreter Lock)

簡單來說,Python全局解釋器鎖(Global Interpreter Lock)或GIL是一個(gè)互斥鎖,它只允許一個(gè)線程來控制Python解釋器。

這意味著在任何時(shí)間點(diǎn)只有一個(gè)線程可以處于執(zhí)行狀態(tài)。執(zhí)行單線程程序的開發(fā)人員感受不到GIL的影響,但它可能是CPU限制型和多線程代碼中的性能瓶頸。

由于即使在具有多個(gè)CPU核心的多線程架構(gòu)中,GIL一次只允許一個(gè)線程執(zhí)行,因此GIL已經(jīng)成為Python“臭名昭著”的特性。

GIL為Python解決了什么問題

Python使用引用計(jì)數(shù)進(jìn)行內(nèi)存管理。這意味著在Python中創(chuàng)建的對象具有引用計(jì)數(shù)變量,該變量用于跟蹤指向該對象的引用數(shù)。當(dāng)此計(jì)數(shù)達(dá)到零時(shí),釋放對象占用的內(nèi)存。

讓我們看一個(gè)簡短的代碼示例來演示引用計(jì)數(shù)的工作原理:

>>>?

>>> import sys

>>> a = []

>>> b = a

>>> sys.getrefcount (a)

3

在上面的示例中,空列表對象的引用計(jì)數(shù)為3。列表對象由a,b引用并且參數(shù)傳遞給sys.getrefcount()。

回到GIL:

問題是這個(gè)引用計(jì)數(shù)變量需要保護(hù)競爭條件。如果其中兩個(gè)線程同時(shí)增加或減少其值,如果發(fā)生這種情況,它可能導(dǎo)致從未釋放的內(nèi)存泄漏,或者更糟糕的是,在對該對象的引用仍然存在時(shí)錯(cuò)誤地釋放內(nèi)存。這可能會(huì)導(dǎo)致Python程序中出現(xiàn)崩潰或其他“怪異”錯(cuò)誤。通過向跨線程共享的所有數(shù)據(jù)結(jié)構(gòu)添加鎖,可以保持此引用計(jì)數(shù)變量的安全性,從而不會(huì)對它們進(jìn)行不一致的修改。

但是為每個(gè)對象或?qū)ο蠼M添加一個(gè)鎖意味著將存在多個(gè)鎖,這可能導(dǎo)致另一個(gè)問題 – 死鎖(死鎖只有在有多個(gè)鎖時(shí)才會(huì)發(fā)生)。另一個(gè)副作用是由于重復(fù)獲取和釋放鎖而導(dǎo)致性能下降。

GIL是解釋器本身的單個(gè)鎖,它增加了一條規(guī)則,即執(zhí)行任何Python字節(jié)碼都需要獲取解釋器鎖。這可以防止死鎖(因?yàn)橹挥幸粋€(gè)鎖)并且不會(huì)引入太多的性能開銷。但它有效地使任何受CPU限制的Python程序都是單線程的。

GIL雖然被解釋器用于其他語言(如Ruby),但并不是解決此問題的少數(shù)方法。有些語言通過使用除引用計(jì)數(shù)之外的方法(例如垃圾收集)來避免GIL對線程安全內(nèi)存管理的要求。

另一方面,這意味著這些語言通常需要通過添加其他性能提升性能(如JIT編譯器)來彌補(bǔ)GIL單線程性能優(yōu)勢的損失。

為什么選擇GIL作為解決方案

那么,為什么在Python中使用的方法看似如此阻礙呢?這是Python開發(fā)人員的糟糕決定嗎?

好吧,用Larry Hastings的話來說, GIL的設(shè)計(jì)決定是讓Python像今天一樣受歡迎的原因之一。

自從操作系統(tǒng)沒有線程概念以來,Python就已存在。Python的設(shè)計(jì)易于使用,以便更快地開發(fā),越來越多的開發(fā)人員開始使用它。

開發(fā)人員正在為Python需要的功能編寫許多C庫擴(kuò)展。為了防止不一致的更改,這些C擴(kuò)展需要GIL提供的線程安全內(nèi)存管理。

GIL易于實(shí)現(xiàn),很容易添加到Python中。它為單線程程序提供了性能提升,因?yàn)橹恍枰芾硪粋€(gè)鎖。

非線程安全的C擴(kuò)展變得更容易集成。這些C擴(kuò)展成為不同社區(qū)愿意采用Python的原因之一。

正如您所看到的,GIL是一個(gè)實(shí)用的解決方案,可以解決CPython開發(fā)人員在Python生命中早期面臨的一個(gè)難題。

對多線程Python程序的影響

當(dāng)您查看典型的Python程序或任何計(jì)算機(jī)程序時(shí),那些在性能上受CPU限制的程序與受I / O限制的程序之間存在差異。

CPU綁定程序是那些將CPU推向極限的程序。這包括進(jìn)行數(shù)學(xué)計(jì)算的程序,如矩陣乘法,搜索,圖像處理等。

I / O綁定程序是花費(fèi)時(shí)間等待輸入/輸出的程序,它可以來自用戶,文件,數(shù)據(jù)庫,網(wǎng)絡(luò)等。I / O綁定程序有時(shí)需要等待很長時(shí)間才能完成從源獲取他們需要的東西,因?yàn)樵纯赡苄枰谳斎?輸出準(zhǔn)備好之前進(jìn)行自己的處理,例如,用戶考慮輸入什么輸入提示或在其中運(yùn)行的數(shù)據(jù)庫查詢自己的過程。

延伸閱讀:

二、什么是Python

Python是一種跨平臺的計(jì)算機(jī)程序設(shè)計(jì)語言。 是一個(gè)高層次的結(jié)合了解釋性、編譯性、互動(dòng)性和面向?qū)ο蟮哪_本語言。最初被設(shè)計(jì)用于編寫自動(dòng)化腳本(shell),隨著版本的不斷更新和語言新功能的添加,越多被用于獨(dú)立的、大型項(xiàng)目的開發(fā)。

聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
TCP擁塞控制算法—優(yōu)缺點(diǎn)、適用環(huán)境、性能分析?

一、TCP擁塞控制算法面向連接的TCP和無連接的UDP在擁塞發(fā)生時(shí)對擁塞指示的不同反應(yīng)和處理,導(dǎo)致對網(wǎng)絡(luò)資源的不公平使用問題。在擁塞發(fā)生時(shí),有...詳情>>

2023-10-11 17:11:33
webpack中的url-loader和file-loader有哪些區(qū)別?

一、webpack中的url-loader和file-loader的區(qū)別1、文件輸出方式不同file-loader會(huì)將文件輸出到指定的輸出目錄,并返回文件的URL地址。url-loade...詳情>>

2023-10-11 17:03:14
為什么iOS始終不支持應(yīng)用雙開深度分析給你答案?

一、為什么iOS始終不支持應(yīng)用雙開應(yīng)用雙開的根本目的我們先從用戶需求的角度來看問題。絕大多數(shù)人需要應(yīng)用雙開,只是因?yàn)橐粋€(gè)APP:微信。我們之...詳情>>

2023-10-11 16:49:08
什么是N+1問題,如何解決 Laravel 的 N+1 問題?

一、N+1問題介紹在基本級別,ORM 是 “懶惰” 加載相關(guān)的模型數(shù)據(jù)。但是,ORM 應(yīng)該如何知道你的意圖?在查詢模型后,您可能永遠(yuǎn)不會(huì)真正使用相...詳情>>

2023-10-11 16:47:26
高并發(fā)、高吞吐是什么?

一、高并發(fā)、高吞吐高吞吐量指的是系統(tǒng)能夠快速處理大量請求的能力,也就是處理更多的請求數(shù)量。高并發(fā)指的是系統(tǒng)能夠同時(shí)處理多個(gè)請求的能力,...詳情>>

2023-10-11 16:43:53
快速通道
主站蜘蛛池模板: 临夏市| 彭山县| 长兴县| 黄陵县| 许昌市| 洞口县| 博爱县| 南乐县| 两当县| 康定县| 射洪县| 神农架林区| 安乡县| 博乐市| 镇康县| 马关县| 杨浦区| 原平市| 新竹市| 遂溪县| 和林格尔县| 喜德县| 乌审旗| 西青区| 东乡县| 二手房| 邓州市| 武义县| 松滋市| 定远县| 湖口县| 莱西市| 越西县| 茌平县| 昌邑市| 丹凤县| 柳江县| 石狮市| 乌苏市| 兴业县| 晋州市|