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