golang中協程和線程的區別


https://www.jianshu.com/p/3b14532c8b36

一般來說,協程就像輕量級的線程。

線程一般有固定的棧,有一個固定的大小。而goroutines為了避免資源浪費(亦或是資源缺乏),采用動態擴張收縮的策略:初始量為2k,最大可以擴張到1G。

每個線程都有一個id,在線程創建的時候就會被返回,所以我們可以通過線程的id來操縱線程。但是在golang中沒有這個概念,因此我們在編碼之初就要考慮協程的創建和釋放問題。

線程和 goroutine 切換調度開銷方面

線程/goroutine 切換開銷方面,goroutine 遠比線程小

線程:涉及模式切換(從用戶態切換到內核態)、16個寄存器、PC、SP...等寄存器的刷新等。

因為協程在用戶態由協程調度器完成,不需要陷入內核,這代價就小了。

所以goroutine:只有三個寄存器的值修改 - PC / SP / DX.



作者:JimmyZhouD
鏈接:https://www.jianshu.com/p/3b14532c8b36
來源:簡書
著作權歸作者所有。商業轉載請聯系作者獲得授權,非商業轉載請注明出處。
 
  • 進程:擁有自己獨立的堆和棧,既不共享堆,也不共享棧,進程由操作系統調度;
  • 線程:擁有自己獨立的棧和共享的堆,共享堆,不共享棧,標准線程由操作系統調度;
  • 協程:擁有自己獨立的棧和共享的堆,共享堆,不共享棧,協程由程序員在協程的代碼里顯式調度


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM