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
來源:簡書
著作權歸作者所有。商業轉載請聯系作者獲得授權,非商業轉載請注明出處。
- 進程:擁有自己獨立的堆和棧,既不共享堆,也不共享棧,進程由操作系統調度;
- 線程:擁有自己獨立的棧和共享的堆,共享堆,不共享棧,標准線程由操作系統調度;
- 協程:擁有自己獨立的棧和共享的堆,共享堆,不共享棧,協程由程序員在協程的代碼里顯式調度