【问题标题】:Getting getrusage() to measure system time in C让 getrusage() 在 C 中测量系统时间
【发布时间】:2012-05-17 14:07:54
【问题描述】:

我想测量执行某些代码所需的系统时间。为此,我知道我会将上述代码夹在两次 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() 来测量某些源代码的系统时间?感谢您的阅读。

【问题讨论】:

  • 请注意tv_usec是微秒,所以你的格式应该是%lu.%06u

标签: c time systemtime getrusage


【解决方案1】:

您应该改用usage.ru_utime,这是用户 CPU 使用时间。

【讨论】:

  • 这确实给了我更好的结果。但是,我仍然有义务找到一种工作方法来测量某些代码的系统时间。如果usage.ru_stime不起作用,有什么用?
  • 如果程序设计为在内核模式下运行,则使用ru_stime。否则,请使用ru_utime
【解决方案2】:

使用 gprof。这将为您提供每个功能所花费的时间。 安装 gprof 并使用这些标志进行编译:-pg -fprofile-arcs -ftest-coverage.

【讨论】:

    【解决方案3】:

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

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

    【讨论】:

    • 谢谢!你比我的教授解释得更好。
    猜你喜欢
    • 1970-01-01
    • 2021-02-11
    • 1970-01-01
    • 1970-01-01
    • 2012-09-05
    • 1970-01-01
    • 2021-03-03
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多