亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

使用 GOMAXPROCS 在 Go 中進行并行編程

使用 GOMAXPROCS 在 Go 中進行并行編程

Go
胡子哥哥 2022-01-04 10:09:00
我看到有人設置runtime.GOMAXPROCS,以runtime.NumCPU()使并行中去處理。官方文檔沒有說明GOMAXPROCS;的上限。我可以將其設置為任意正整數,還是應該始終小于 eq. 以 NumCPU價值?我試著將它設置為一個數字,比更大#的邏輯核心,我的代碼工作得很好
查看完整描述

2 回答

?
MM們

TA貢獻1886條經驗 獲得超2個贊

GOMAXPROCS由于運行時會為您與操作系統進行交互,因此您不需要在大多數時候搞砸。 GOMAXPROCS過去默認為 1,但在 Go 1.5 中,現在默認為NumCPU()

將其設置為高于 NumCPU 只會為調度程序提供更多(不必要的)處理操作系統線程的工作。


查看完整回答
反對 回復 2022-01-04
?
慕勒3428872

TA貢獻1848條經驗 獲得超6個贊

最大值為 256;但請注意,如果您將其設置得更高,則不會出錯。


https://golang.org/src/runtime/debug.go?s=534:560#L7


12  // GOMAXPROCS sets the maximum number of CPUs that can be executing

13  // simultaneously and returns the previous setting.  If n < 1, it does not

14  // change the current setting.

15  // The number of logical CPUs on the local machine can be queried with NumCPU.

16  // This call will go away when the scheduler improves.

17  func GOMAXPROCS(n int) int {

18      if n > _MaxGomaxprocs {

19          n = _MaxGomaxprocs

20      }

21      lock(&sched.lock)

22      ret := int(gomaxprocs)

23      unlock(&sched.lock)

24      if n <= 0 || n == ret {

25          return ret

26      }

27  

28      stopTheWorld("GOMAXPROCS")

29  

30      // newprocs will be processed by startTheWorld

31      newprocs = int32(n)

32  

33      startTheWorld()

34      return ret

35  }

Line 19將總數設置為_MaxGomaxprocs。


這是...


https://golang.org/src/runtime/runtime2.go?h=_MaxGomaxprocs#L407


const (

    // The max value of GOMAXPROCS.

    // There are no fundamental restrictions on the value.

    _MaxGomaxprocs = 1 << 8

)

二進制形式的位移是100000000和 1 是int在 64 位系統上,Go 使其成為 Int64,這意味著最大值是 256。(intGo 中的32 位系統將是 int32,但值為 256)


現在,只要將其設置為多于您的內核數量 - 這一切都取決于您的工作負載和正在發生的 CPU 上下文切換(例如,您的 go 程序強制發生多少鎖,或者您是否mutex.Lock()在任何地方使用等)。


請記住,無論是否需要,Golang 都會抽象出上下文切換。


基準測試是您的朋友。如果您的應用程序運行 10,000 個 goroutine,而幾乎沒有 cpu 上下文切換(遵循良好的設計模式),那么是的,將那個吸盤提升到 256 并讓它運行。如果您的應用程序阻塞并通過上下文切換/線程創建大量 CPU 等待時間,則將其設置為 8 或 4,甚至可以在所有mutex鎖定進行時為其提供喘息的空間。


查看完整回答
反對 回復 2022-01-04
  • 2 回答
  • 0 關注
  • 308 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號