gpt4 book ai didi

c - 在 C 中获取 getrusage() 来测量系统时间

转载 作者:太空狗 更新时间:2023-10-29 16:47:43 28 4
gpt4 key购买 nike

我想测量执行某些代码所需的系统时间。为此,我知道我会将所述代码夹在对 getrusage() 的两次调用之间,但我得到了一些意想不到的结果......

#include <sys/time.h>
#include <sys/resource.h>
#include <unistd.h>
#include <stdio.h>

int main() {
struct rusage usage;
struct timeval start, end;
int i, j, k = 0;

getrusage(RUSAGE_SELF, &usage);
start = usage.ru_stime;
for (i = 0; i < 10000; i++) {
/* Double loop for more interesting results. */
for (j = 0; j < 10000; j++) {
k += 20;
}
}
getrusage(RUSAGE_SELF, &usage);
end = usage.ru_stime;

printf("Started at: %ld.%lds\n", start.tv_sec, start.tv_usec);
printf("Ended at: %ld.%lds\n", end.tv_sec, end.tv_usec);
return 0;
}

我希望这会产生两个不同的数字,但是唉!在看到我的计算机思考一两秒钟后,结果如下:

Started at: 0.1999s
Ended at: 0.1999s

我不是在使用 getrusage() 吗?为什么这两个数字不应该不同?如果我从根本上错了,还有另一种方法可以使用 getrusage() 来测量某些源代码的系统时间吗?感谢您的阅读。

最佳答案

您误解了“用户”和“系统”时间之间的区别。您的示例代码在您测量时主要在用户模式下执行(即,运行您的应用程序代码),但“系统”时间是对在内核模式下执行所花费的时间(即,处理系统调用)的度量。

ru_stime 是测量系统时间的正确字段。您的测试应用程序恰好不会在您检查的两点之间累积任何此类时间。

关于c - 在 C 中获取 getrusage() 来测量系统时间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10509660/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com