我试图了解如何
int getrusage(int who, struct rusage* usage)
工作以计算我的一个程序的运行时间。
我红了手册页,可能 10 次,但仍然无法得到它。试图在网上找到一些东西,但只找到有关此功能的手册页。
我不清楚的是存储在 rusage 结构中的内容 - 手册页不是很清楚 - 所以我尝试使用调试器运行它并直接查看里面的内容,但仍然不明白,尤其是这两个结构- timeval ru_utime 和 timeval ru_stime - 工作。
它们内部的内容假设不同的值,有时为 0,有时为 2000 等。
我运行了一个带有 for 循环的简单程序,该循环不断地分配和释放内存。我用秒表实际查看需要多少时间,花了 5.23 秒。但我在这些结构中看到的似乎完全不相关:
循环前:
ru_utime = { tv_sec = 0, tv_usec = 1000}, ru_stime = { tv_sec = 0, tv_usec = 1000}
循环后:
ru_utime = { tv_sec = 4, tv_usec = 677000}, ru_stime = { tv_sec = 0, tv_usec = 2000}
所以,谁能给我解释一下或者给出一些很好的链接来解释这个?
我将不胜感激。