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

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

如果 GOMAXPROCS 太大怎么辦?

如果 GOMAXPROCS 太大怎么辦?

Go
絕地無雙 2023-07-10 10:42:16
我們都知道runtime.GOMAXPROCS默認設置為CPU核心數,如果這個屬性設置太大怎么辦?程序會有更多的上下文切換嗎?垃圾收集器會被更頻繁地觸發嗎?
查看完整描述

1 回答

?
函數式編程

TA貢獻1807條經驗 獲得超9個贊

GOMAXPROCS默認情況下設置為可用邏輯 CPU 的數量是有原因的:這在大多數情況下提供最佳性能。

GOMAXPROCS僅限制“活動”線程的數量,如果線程的 goroutine 被阻塞(例如通過系統調用),則可能會啟動新線程。

如果GOMAXPROCS大于可用 CPU 的數量,則活動線程數將多于 CPU 核心數,這意味著活動線程必須“多路復用”到可用處理單元,所以是的,如果有更多的線程,將會有更多的上下文切換活動線程多于核心,但情況不一定如此。

垃圾收集與線程數沒有直接關系,因此您不必擔心這一點。引用自包runtime

GOGC 變量設置初始垃圾收集目標百分比。當新分配的數據與上次收集后剩余的實時數據的比例達到此百分比時,將觸發收集。默認值為 GOGC=100。設置 GOGC=off 會完全禁用垃圾收集器。運行時/調試包的 SetGCPercent 函數允許在運行時更改此百分比。

如果您有更多不分配/釋放內存的線程,那么這不會影響觸發集合的頻率。

在某些情況下,設置GOMAXPROCS高于 CPU 數量可能會提高應用程序的性能,但這種情況很少見。衡量一下它是否對您的情況有幫助。


查看完整回答
反對 回復 2023-07-10
  • 1 回答
  • 0 關注
  • 162 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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