小编Sto*_*Joe的帖子

获取getrusage()以C语言测量系统时间

我想测量执行一些代码所需的系统时间.要做到这一点,我知道我会在两次调用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;
}
Run Code Online (Sandbox Code Playgroud)

我希望这会产生两个不同的数字,但唉!看到我的电脑想了一两秒后,这就是结果: …

c time systemtime getrusage

10
推荐指数
1
解决办法
3万
查看次数

标签 统计

c ×1

getrusage ×1

systemtime ×1

time ×1