您好,登錄后才能下訂單哦!
今天小編給大家分享一下Python中GIL全局解釋鎖如何實現的相關知識點,內容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。
設計者為了規避類似于內存管理這樣的復雜的競爭風險問題(race condition)
因為 CPython 大量使用 C 語言庫,但大部分C語言庫都不是原生線程安全的(線程安全會降低性能和增加復雜度)
多個線程執行時,每一個線程在開始執行時,都會鎖住 GIL,以阻止別的線程執行,同樣的,每一個線程執行完一段后,會釋放 GIL,以允許別的線程開始利用資源
CPython 中還有另一個機制,叫做 check_interval, CPython 解釋器會去輪詢檢查線程 GIL 的鎖住情況.每隔一段時間,Python 解釋器就會強制當前線程去釋放 GIL,這樣別的線程才能有執行的機會
for (;;) { if (--ticker < 0) { ticker = check_interval; /* Give another thread a chance */ PyThread_release_lock(interpreter_lock); /* Other threads may run now */ PyThread_acquire_lock(interpreter_lock, 1); } bytecode = *next_instr++; switch (bytecode) { /* execute the next instruction ... */ } }
有了GIL,任然在編程時需要考慮線程安全
繞過 CPython,使用 JPython(Java 實現的Python解釋器)等別的實現
把關鍵性能代碼,放到別的語言(一般是 C++)中實現
GIL采用輪流運行線程的機制,GIL需要在線程之間不斷輪流進行切換,線程如果多或者運行時間較長,切換帶來的性能損失可能超過單線程
事實上,在 Python 3 之后,確實有很多關于 GIL 改進甚至是取消的討論,你的看法是什么呢?你在平常工作中有被 GIL 困擾過的場景嗎?
GIL任然是一個好的設計雖然損失了性能,但在保證資源不會沖突和預防死鎖方面有一定作用
以上就是“Python中GIL全局解釋鎖如何實現”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。