目前我正在用golang編寫在線判斷系統(tǒng)。為了檢測用戶程序內(nèi)存使用情況,我決定分析cmd.ProcessState.SysUsage()和檢查Rusage.Maxrss. 現(xiàn)在我很困惑,因為當(dāng)我嘗試在我的 mac 上運行它時,Rusage.Maxrss調(diào)用結(jié)果很奇怪這是我在 macOS 和 Linux 上運行的代碼(它已簡化,Getrusage()當(dāng)前進程的此代碼調(diào)用)并且我得到了結(jié)果:package mainimport ( "fmt" "syscall")func main() { rusage := syscall.Rusage{} pageSize := syscall.Getpagesize() if err := syscall.Getrusage(syscall.RUSAGE_SELF, &rusage); err != nil { fmt.Println(err) panic(err) } fmt.Printf("page size: %d\nrusage.Maxrss: %d\n", pageSize, rusage.Maxrss)}以下是我得到的結(jié)果蘋果系統(tǒng):go run test.go page size: 4096rusage.Maxrss: 2007040Linux/Ubuntu-18.04:go run test.go page size: 4096rusage.Maxrss: 17580你能解釋一下為什么它會返回這么大的價值嗎?正如我所看到的 macOS 手冊和 linux 手冊頁:rusage.Maxrss(或rusage.ru_maxrss來自C語言)以千字節(jié)為單位,所以在 macOS 上我的代碼使用了 ~2GB 的內(nèi)存,而在 Linux 上它只使用了 ~20MB?這是一個很好的決定來衡量用戶程序使用的內(nèi)存rusage.Maxrss 還是有更好的方法?
1 回答

呼喚遠方
TA貢獻1856條經(jīng)驗 獲得超11個贊
在我的 Mac 上,getrusage()
手冊頁說:“ ru_maxrss使用的最大駐留集大小(以字節(jié)為單位)”(添加了重點)。這似乎對你的結(jié)果有意義。
您所指的Apple遺留文檔檔案中的iOS手冊頁確實說單位是千字節(jié)。目前尚不清楚這是由于 iOS 和 macOS 之間的行為不同,還是由于手冊頁中的錯誤已得到糾正。遺憾的是,Apple 沒有在線維護維護手冊頁。
- 1 回答
- 0 關(guān)注
- 144 瀏覽
添加回答
舉報
0/150
提交
取消