這篇文章主要介紹了python GIL怎么用,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
python常用的庫:1.requesuts;2.scrapy;3.pillow;4.twisted;5.numpy;6.matplotlib;7.pygama;8.ipyhton等。
1、用處
解決多線程間數據的完整性和狀態同步問題。
例如,Python對象的管理是用引用計數器進行的,引用數為0釋放對象。開始:線程a和線程b引用對象obj、obj.ref_num=2,線程a和b都想取消obj的引用。
2、避免GIL帶來的限制
(1)多線程threading機制仍然有用,用IO密集型計算。在I/O(read、write、send、recv、etc.)期間,線程釋放GIL,實現CPU和IO的并行。因此,多線程用于IO密集型計算,可以大幅度提高速度。然而,當多線程用于計算中央處理器密集時,只會更慢。
(2)使用multiprocessing的多過程機制實現并行計算,利用多核心CPU的優勢。為了應對GIL的問題,Python提供了multiprocessing。
感謝你能夠認真閱讀完這篇文章,希望小編分享的“python GIL怎么用”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。