掃二維碼與項(xiàng)目經(jīng)理溝通
我們?cè)谖⑿派?4小時(shí)期待你的聲音
解答本文疑問(wèn)/技術(shù)咨詢/運(yùn)營(yíng)咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流
釋放GIL鎖原理分析

公司主營(yíng)業(yè)務(wù):成都網(wǎng)站設(shè)計(jì)、做網(wǎng)站、移動(dòng)網(wǎng)站開(kāi)發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實(shí)現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競(jìng)爭(zhēng)能力。創(chuàng)新互聯(lián)是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊(duì)。公司秉承以“開(kāi)放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對(duì)我們的高要求,感謝他們從不同領(lǐng)域給我們帶來(lái)的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會(huì)用頭腦與智慧不斷的給客戶帶來(lái)驚喜。創(chuàng)新互聯(lián)推出山海關(guān)免費(fèi)做網(wǎng)站回饋大家。
1、在單核CPU下,這種情況并不特別糟糕。由于只有一個(gè)CPU,CPU的利用率非常高。
2、在多核CPU下,由于GIL鎖的整體特性,無(wú)法發(fā)揮多核特性,GIL鎖大大降低了多線程任務(wù)的效率。
盡管全部釋放GIL鎖,但是這兩種情況是不同的。例如,Thread1遇到IO操作釋放GIL,由Thread2和Thread3來(lái)競(jìng)爭(zhēng)GIL鎖,Thread1將不再參與這場(chǎng)競(jìng)爭(zhēng)。假如是Thread1因?yàn)門(mén)imeTick過(guò)期而釋放GIL(大多數(shù)是CPU密集任務(wù)),那么三個(gè)線程就能同時(shí)競(jìng)爭(zhēng)GIL鎖,這可能會(huì)導(dǎo)致Thread1在競(jìng)爭(zhēng)中獲勝并重新執(zhí)行。
線程釋放GIL鎖有兩種情況
一種是IO操作,另一種是TimeTick過(guò)期。IO操作很好理解,比如發(fā)出http請(qǐng)求,等待響應(yīng)。那么什么是TimeTick過(guò)期呢?TimeTick規(guī)定了線程的最長(zhǎng)執(zhí)行時(shí)間,超過(guò)時(shí)間后自動(dòng)釋放GIL鎖。python3之后,間隔時(shí)間約為15毫秒。
以上就是python GIL鎖的底層原理探究,希望對(duì)大家有所幫助。更多Python學(xué)習(xí)指路:創(chuàng)新互聯(lián)python教程
本文教程操作環(huán)境:windows7系統(tǒng)、Python 3.9.1,DELL G3電腦。

我們?cè)谖⑿派?4小時(shí)期待你的聲音
解答本文疑問(wèn)/技術(shù)咨詢/運(yùn)營(yíng)咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流