python GIL鎖

來源:互聯網
上載者:User

標籤:全域   ima   計算   修改   gil   png   blog   logs   上下   

GIL鎖 全域解譯器鎖

無論cpu是多少核的,python同一時間執行的線程只有一個,但是給我們的感覺是並發的?因為python在不斷的進行內容相關的切換。

python的線程是叫用作業系統的原生線程。因為調用的是c的介面。當Python要調用這個線程去執行任務的時候,cpu要知道上下文,所以要把上下文關係傳給cpu。

 

要求是起4個線程,每起一個線程num+1 。因為每個線程都是獨立並存執行的,所以他們得到的num都是等於1,那麼返回的結果都是2。他們計算的時候也是並行的不是串列的。

可能每個線程分到不同的cpu核心上,但是同一時間只有一個在執行。避免資料出錯,Python加一個全域鎖,同一時間,只有一個線程能拿到這個資料。去修改。

因為在多線程中,所有變數都由所有線程共用,所以,任何一個變數都可以被任何一個線程修改,因此,線程之間共用資料最大的危險在於多個線程同時改一個變數,把內容給改亂了。

python GIL鎖

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.