首頁 >後端開發 >Golang >golang是多執行緒模式嗎?

golang是多執行緒模式嗎?

coldplay.xixi
coldplay.xixi原創
2020-07-22 09:31:365870瀏覽

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

golang是多執行緒模式嗎?

golang是多執行緒模式。

 由於gmp中的p與m是將p綁定與m內核線程上,而後p的最大數量有GOPROCESS確定,而M內核線程的數量會由go去限制為10K個,但是由於內核原因做不到這麼多,所以這個限制就當做沒有吧。拿個圖明確一下

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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn