我想测量它需要执行一些代码的系统时间。 要做到这一点,我知道我会说三明治两个电话之间的代码的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()来衡量的一些源代码的系统时间? 谢谢您的阅读。