一区二区三区中文国产亚洲_另类视频区第一页_日韩精品免费视频_女人免费视频_国产综合精品久久亚洲

千鋒教育-做有情懷、有良心、有品質(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的影響

Python之如何避免受到GIL的影響

來源:千鋒教育
發(fā)布人:xqq
時(shí)間: 2023-11-06 17:35:06 1699263306

GIL這么爛,有沒有辦法繞過呢?我們來看看有哪些現(xiàn)成的python方案。

用multiprocess替代Thread

multiprocess庫的出現(xiàn)很大程度上是為了彌補(bǔ)thread庫因?yàn)镚IL而低效的缺陷。它完整的復(fù)制了一套thread所提供的接口方便遷移。唯一的不同就是它使用了多進(jìn)程而不是多線程。每個(gè)進(jìn)程有自己的獨(dú)立的GIL,因此也不會(huì)出現(xiàn)進(jìn)程之間的GIL爭(zhēng)搶。

當(dāng)然multiprocess也不是萬能良藥。它的引入會(huì)增加程序?qū)崿F(xiàn)時(shí)線程間數(shù)據(jù)通訊和同步的困難。就拿計(jì)數(shù)器來舉例子,如果我們要多個(gè)線程累加同一個(gè)變量,對(duì)于thread來說,申明一個(gè)global變量,用thread.Lock的context包裹住三行就搞定了。而multiprocess由于進(jìn)程之間無法看到對(duì)方的數(shù)據(jù),只能通過在主線程申明一個(gè)Queue,put再get或者用sharememory的方法。這個(gè)額外的實(shí)現(xiàn)成本使得本來就非常痛苦的多線程程序編碼,變得更加痛苦了。

用其他解析器

之前也提到了既然GIL只是CPython的產(chǎn)物,那么其他解析器是不是更好呢?沒錯(cuò),像JPython和IronPython這樣的解析器由于實(shí)現(xiàn)語言的特性,他們不需要GIL的幫助。然而由于用了Java/C#用于解析器實(shí)現(xiàn),他們也失去了利用社區(qū)眾多C語言模塊有用特性的機(jī)會(huì)。所以這些解析器也因此一直都比較小眾。畢竟功能和性能大家在初期都會(huì)選擇前者,Doneisbetterthanperfect。

所以沒救了么?

當(dāng)然Python社區(qū)也在非常努力的不斷改進(jìn)GIL,甚至是嘗試去除GIL。并在各個(gè)小版本中有了不少的進(jìn)步。有興趣的讀者可以擴(kuò)展閱讀這個(gè)Slide

另一個(gè)改進(jìn)ReworkingtheGIL

–將切換顆粒度從基于opcode計(jì)數(shù)改成基于時(shí)間片計(jì)數(shù)

–避免最近一次釋放GIL鎖的線程再次被立即調(diào)度

–新增線程優(yōu)先級(jí)功能(高優(yōu)先級(jí)線程可以迫使其他線程釋放所持有的GIL鎖)

以上內(nèi)容為大家介紹了Python之如何避免受到GIL的影響,希望對(duì)大家有所幫助,如果想要了解更多Python相關(guān)知識(shí),請(qǐng)關(guān)注IT培訓(xùn)機(jī)構(gòu):千鋒教育。http://m.fengjieshuijing.cn/

聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請(qǐng)您保持通訊暢通,專屬學(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
python的深淺拷貝

1.python中,對(duì)象賦值實(shí)際是對(duì)對(duì)象的引用,比如:alist=[1,2,[1,2,3]]b=alist其中,b就是直接引用**ist指向的對(duì)象,也就是內(nèi)存中heap中的一個(gè)值...詳情>>

2023-11-06 20:35:06
python中文件操作的一些函數(shù)

文件操作的所有函數(shù):注意python2與3有些函數(shù)的用法還不一樣,python3就嚴(yán)格區(qū)分一些標(biāo)識(shí)符,比如win下面的文件E:\m.txt,2里面就沒有這么多窮講...詳情>>

2023-11-06 20:31:30
Python圖形應(yīng)用GUI開發(fā)框架

作為Pyhon開發(fā)者,你遲早都會(huì)碰到圖形用戶界面(GUI)應(yīng)用開發(fā)任務(wù),目前市場(chǎng)上有大量PythonGUI開發(fā)框架可供選擇,PythonwikiGUIprogramming給出...詳情>>

2023-11-06 20:09:54
Python 中少為人知的十個(gè)安全陷阱!

Python開發(fā)者們?cè)谑褂脴?biāo)準(zhǔn)庫和通用框架時(shí),都以為自己的程序具有可靠的安全性。然而,在Python中,就像在任何其它編程語言中一樣,有一些特性可...詳情>>

2023-11-06 19:59:06
python修改列表元素有什么方法

增刪改查是處理數(shù)據(jù)最常見的方法,前兩種說過了,這里就要說說python提供的兩種修改列表元素的方法,一種是修改單個(gè)元素,還有一種的修改一組數(shù)...詳情>>

2023-11-06 18:29:06