您好,登錄后才能下訂單哦!
golang中協程和線程的區別
一般來說,協程就像輕量級的線程。
線程一般有固定的棧,有一個固定的大小。而goroutines為了避免資源浪費(亦或是資源缺乏),采用動態擴張收縮的策略:初始量為2k,最大可以擴張到1G。
每個線程都有一個id,在線程創建的時候就會被返回,所以我們可以通過線程的id來操縱線程。但是在golang中沒有這個概念,因此我們在編碼之初就要考慮協程的創建和釋放問題。
線程和 goroutine 切換調度開銷方面
線程/goroutine 切換開銷方面,goroutine 遠比線程小
線程:涉及模式切換(從用戶態切換到內核態)、16個寄存器、PC、SP...等寄存器的刷新等。
因為協程在用戶態由協程調度器完成,不需要陷入內核,這代價就小了。
所以goroutine:只有三個寄存器的值修改 - PC / SP / DX.
以上就是golang中協程和線程的區別是什么?的詳細內容,更多請關注億速云其它相關文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。