首頁 > 後端開發 > Golang > golang是單進程的嗎?

golang是單進程的嗎?

coldplay.xixi
發布: 2020-07-22 09:25:29
原創
4398 人瀏覽過

golang不是單一行程的,而是多執行緒;golang的執行緒模型是M P G模型,整體上Go程與核心執行緒是多對多對應的,因此首先來講就一定是多執行緒的。

golang是單進程的嗎?

golang不是單一進程的,而是多執行緒。

Golang有些所謂的M比N模型,M個執行緒下可以創建N個go routine,一般而言N遠大於M,本質上屬於多執行緒模型,但是協程的調度由Go的runtime決定,強調開發者應該使用channel進行協程之間的同步。

至於線程,由於語言層面上不開放,你可以理解為其其實是多協程模型,一個線程上可以創建若干個go routine,一般而言會創建與CPU核心數相同的執行緒數,當然實際上還是由runtime決定。

對於goroutine的調度,這個其實是一直在發展變化的,我只說一下GMP模型,goroutine在M個執行緒上運行,每次執行任務都會去查當前P (處理器)上的可執行隊列,隊列裡面就是可以執行的goroutine,一旦當前P上沒有可供執行的它就會去竊取另一個P的可執行隊列中的goroutine。

而goroutine的創建理論上只受記憶體限制,一般來說最大也就2KB,對於一個線程2MB空間大小理論上來說可以輕易上1000個,當然這只是理想情況下,所以OS線程數不會隨著goroutine創建個數增加而增加。線程調度是對於go來說會比較耗費性能,頻繁切換調度只會在goroutine之間存在,線程只會保持與cpu數相同的活躍線程數。

相關學習推薦:Go語言教學

以上是golang是單進程的嗎?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板