卖逼视频免费看片|狼人就干网中文字慕|成人av影院导航|人妻少妇精品无码专区二区妖婧|亚洲丝袜视频玖玖|一区二区免费中文|日本高清无码一区|国产91无码小说|国产黄片子视频91sese日韩|免费高清无码成人网站入口

分布式系統(tǒng) go是多線程還是協(xié)程?

go是多線程還是協(xié)程?3.1 concept在Go程序中,它由輕量級線程實現(xiàn),由Go運行時管理。3.2與進程和線程的區(qū)別1)進程有自己的獨立堆棧,既不共享堆棧,也不共享堆棧。由操作系統(tǒng)安排。2)線程有

go是多線程還是協(xié)程?

3.1 concept

在Go程序中,它由輕量級線程實現(xiàn),由Go運行時管理。

3.2與進程和線程的區(qū)別

1)進程有自己的獨立堆棧,既不共享堆棧,也不共享堆棧。由操作系統(tǒng)安排。

2)線程有自己的獨立堆棧和共享堆。共享堆和非共享堆由操作系統(tǒng)調度。

2)協(xié)同程序共享堆,但不共享堆棧。

3.3主線程與協(xié)程的關系

3.4協(xié)程輕于線程的原因

3.4.1線程的并發(fā)進程

線程是內核提供的服務。應用程序通過系統(tǒng)調用使內核啟動線程,內核負責線程調度和切換。當線程正在等待I/O操作時,當線程變?yōu)椴豢擅麪顟B(tài)時,將觸發(fā)上下文切換?,F(xiàn)代操作系統(tǒng)一般采用搶占式調度。上下文切換通常發(fā)生在時鐘中斷和系統(tǒng)調用返回之前。調度器計算當前線程的時間片。如果需要切換,則從隊列中選擇一個目標線程,保存當前線程的環(huán)境,并恢復目標線程的運行環(huán)境。最典型的方法是將ESP切換為指向目標線程內核堆堆棧,將EIP指向上次調度時目標線程的指令地址。

3.4.2協(xié)程并發(fā)進程

不依賴于操作系統(tǒng)及其提供的線程。golang自己實現(xiàn)的CSP并發(fā)模型:m,P,g

go corroutine也稱為用戶模式線程,在用戶模式下進行corroutine之間的切換。在用戶模式下,沒有時鐘中斷、系統(tǒng)調用等機制,效率高。

3.5 go協(xié)程占用內存較少的原因

執(zhí)行go協(xié)程只需要很少的堆棧內存(約4-5kb)。默認情況下,線程堆棧大小為1MB。

goroutine是在堆上分配的一段代碼、一個函數(shù)項和一個堆棧。因此,我們可以輕松地創(chuàng)建數(shù)以萬計的goroutine,但它們不是由操作系統(tǒng)調度的。