欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python中GIL的原理及用法總結(jié)

 更新時間:2021年03月08日 08:25:22   作者:小妮淺淺  
在本篇文章里小編給大家整理的是一篇關(guān)于python中GIL的原理及用法總結(jié)內(nèi)容,有需要的朋友們可以學(xué)習(xí)參考下。

1、說明

GIL規(guī)定一個Python解釋程序只能同時由一個線程控制。

在CPU限制類型和多線程代碼中,GIL是一個性能瓶頸。

GIL使Python多線程成為偽并行多線程。

僅CPython解釋器上存在GIL。

2、原理

(1)線程1、2、3輪流執(zhí)行,每一個線程在執(zhí)行是,都會鎖住GIL,以阻止別的線程執(zhí)行;

同樣的,每一個線程執(zhí)行一段后,會釋放GIL,以允許別的線程開始利用資源。

(2)由于古老GIL機制,如果線程2需要在CPU2上執(zhí)行,它需要先等待在CPU1上執(zhí)行的線程1釋放GIL(記?。篏IL是全局的)

(3)如果線程1是因為 i/o 阻塞讓出的GIL,那么線程2必定拿到GIL。但如果線程1是因為timer ticks計數(shù)滿100ticks(大概對應(yīng)了1000個bytecodes)讓出GIL,那么這個時候線程1和線程2公平競爭。

(4)但要命的是,在Python 2.x, 線程1不會動態(tài)的調(diào)整自身的優(yōu)先級,所以很大概率下次被選中執(zhí)行的還是線程1,在很多個這樣的選舉周期內(nèi),線程2只能安靜的看著線程1拿著GIL在CPU 1上歡快的執(zhí)行。

(5)極端一點的情況下,比如線程1使用了while True在CPU1上執(zhí)行,那就真是“一核有難,八核圍觀”了。

知識點擴展:

GIL設(shè)計理念與限制

python的代碼執(zhí)行由python虛擬機(也叫解釋器主循環(huán),CPython版本)來控制,python在設(shè)計之初就考慮到在解釋器的主循環(huán)中,同時只有一個線程在運行。即在任意時刻只有一個線程在解釋器中運行。對python虛擬機訪問的控制由全局解釋鎖GIL控制,正是這個鎖來控制同一時刻只有一個線程能夠運行。

在調(diào)用外部代碼(如C、C++擴展函數(shù))的時候,GIL將會被鎖定,直到這個函數(shù)結(jié)束為止(由于期間沒有python的字節(jié)碼運行,所以不會做線程切換)。

在python中使用都是操作系統(tǒng)級別的線程,linux中使用的pthread,window使用的是其原生線程。

從上面的概述中可以直觀的看出py在同一時刻只能跑一個線程,這樣在跑多線程的情況下,只有當(dāng)線程獲取到全局解釋器鎖后才能運行,而全局解釋器鎖只有一個,因此即使在多核的情況下也只能發(fā)揮出單核的功能。

那么這樣看起來py不給力啊,GIL直接導(dǎo)致CPython不能利用物理多核的性能加速運行。那么為什么會有這樣的設(shè)計?考慮到Guido van Rossum 在創(chuàng)造python的時候,上世紀(jì)90年代,多核cpu完全屬于不可想象的,現(xiàn)在由于硬件發(fā)展速度太快,程序編寫就要考慮用盡cpu的全部性能,否則就要被淘汰,那么對于python同樣也要如此。

上面主要說的是這種設(shè)計的劣勢,下面再討論它的優(yōu)勢。

GIL的設(shè)計簡化了CPython的實現(xiàn),使得對象模型,包括關(guān)鍵的內(nèi)建類型如字典,都隱式可以并發(fā)訪問。鎖住全局解釋器使得其比較容易的實現(xiàn)對多線程的支持,但也折損了多處理器主機的并行計算能力。

但是不論標(biāo)準(zhǔn)的,還是第三方的擴展模塊,都被設(shè)計成在進行密集計算任務(wù)時釋放GIL。另外還有在做IO操作時,GIL總是被釋放。對所有面對內(nèi)建的操作系統(tǒng)C代碼的程序來說,GIL會在這個IO調(diào)用之前被釋放,以允許其它的線程在等待這個IO的時候運行。如果是純計算的程序,沒有IO操作,解釋器會每隔100次或每隔一定時間15ms去釋放GIL。

這里可以理解為IO密集型的python比計算密集型的程序更能利用多線程環(huán)境帶來的便利。

到此這篇關(guān)于python中GIL的原理及用法總結(jié)的文章就介紹到這了,更多相關(guān)python中GIL的原理內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python分析微信好友性別比例和省份城市分布比例的方法示例【基于itchat模塊】

    Python分析微信好友性別比例和省份城市分布比例的方法示例【基于itchat模塊】

    這篇文章主要介紹了Python分析微信好友性別比例和省份城市分布比例的方法,結(jié)合實例形式分析了Python基于itchat模塊獲取及計算微信好友相關(guān)信息操作技巧,需要的朋友可以參考下
    2020-05-05
  • PyTorch 中的 torch.utils.data 解析(推薦)

    PyTorch 中的 torch.utils.data 解析(推薦)

    這篇文章主要介紹了PyTorch?torch.utils.data.Dataset概述案例詳解,主要介紹對?torch.utils.data.Dataset?的理解,需要的朋友可以參考下
    2023-02-02
  • Python的Django框架中使用SQLAlchemy操作數(shù)據(jù)庫的教程

    Python的Django框架中使用SQLAlchemy操作數(shù)據(jù)庫的教程

    SQLAlchemy是Python一個專門的數(shù)據(jù)庫管理工具,如果對Django ORM覺得有些生疏的話完全可以結(jié)合SQLAlchemy,這里我們就來總結(jié)一下Python的Django框架中使用SQLAlchemy操作數(shù)據(jù)庫的教程
    2016-06-06
  • Python OpenCV 使用滑動條來調(diào)整函數(shù)參數(shù)的方法

    Python OpenCV 使用滑動條來調(diào)整函數(shù)參數(shù)的方法

    這篇文章主要介紹了Python OpenCV 使用滑動條來調(diào)整函數(shù)參數(shù)的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • Numpy中np.dot與np.matmul的區(qū)別詳解

    Numpy中np.dot與np.matmul的區(qū)別詳解

    本文主要介紹了Numpy中np.dot與np.matmul的區(qū)別詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-02-02
  • tensorflow實現(xiàn)加載mnist數(shù)據(jù)集

    tensorflow實現(xiàn)加載mnist數(shù)據(jù)集

    這篇文章主要為大家詳細(xì)介紹了tensorflow實現(xiàn)加載mnist數(shù)據(jù)集,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-09-09
  • python中urllib模塊用法實例詳解

    python中urllib模塊用法實例詳解

    這篇文章主要介紹了python中urllib模塊用法,以實例形式詳細(xì)分析了python中urllib模塊代替PHP的curl操作方法,具有不錯的借鑒價值,需要的朋友可以參考下
    2014-11-11
  • Python中的正則表達(dá)式與JSON數(shù)據(jù)交換格式

    Python中的正則表達(dá)式與JSON數(shù)據(jù)交換格式

    正則表達(dá)式 是一個特殊的字符序列,一個字符串是否與我們所設(shè)定的這樣的字符序列,相匹配快速檢索文本、實現(xiàn)替換文本的操作。這篇文章主要介紹了Python中的正則表達(dá)式與JSON ,需要的朋友可以參考下
    2019-07-07
  • Python在groupby分組后提取指定位置記錄方法

    Python在groupby分組后提取指定位置記錄方法

    下面小編就為大家分享一篇Python在groupby分組后提取指定位置記錄方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-04-04
  • Python urlopen()函數(shù) 示例分享

    Python urlopen()函數(shù) 示例分享

    urlopen(url, data=None, proxies=None) 即創(chuàng)建一個表示遠(yuǎn)程url的類文件對象,然后像本地文件一樣操作這個類文件對象來獲取遠(yuǎn)程數(shù)據(jù)。參數(shù)url表示遠(yuǎn)程數(shù)據(jù)的路徑,一般是網(wǎng)址;參數(shù)data表示以post方式提交到url的數(shù)據(jù);參數(shù)proxies用于設(shè)置代理。
    2014-06-06

最新評論