【问题标题】:UNIX System time and User time. C-ProgrammingUNIX 系统时间和用户时间。 C-编程
【发布时间】:2009-09-23 23:43:33
【问题描述】:

您好,我正在尝试获取程序消耗的系统时间和用户时间。我遇到了一些麻烦,因为我的时间总是以毫秒为单位为零。我想我做错了什么。你能指引我正确的方向吗?我的两个方法都返回 0

typedef struct{
    struct timeval ru_utime; /* user time used */
    struct timeval ru_stime; /* system time used */
    long   ru_maxrss;        /* maximum resident set size */
    long   ru_ixrss;         /* integral shared memory size */
    long   ru_idrss;         /* integral unshared data size */
    long   ru_isrss;         /* integral unshared stack size */
    long   ru_minflt;        /* page reclaims */
    long   ru_majflt;        /* page faults */
    long   ru_nswap;         /* swaps */
    long   ru_inblock;       /* block input operations */
    long   ru_oublock;       /* block output operations */
    long   ru_msgsnd;        /* messages sent */
    long   ru_msgrcv;        /* messages received */
    long   ru_nsignals;      /* signals received */
    long   ru_nvcsw;         /* voluntary context switches */
    long   ru_nivcsw;        /* involuntary context switches */
}rusage;


/*************************************************************/


double getsystemtime(){
    struct timeval tim;
    struct rusage ru;
    getrusage(RUSAGE_SELF, &ru);
    tim = ru.ru_stime;
    double t = (double)tim.tv_sec / 1000.0;
    return t;
}

double getusertime(){
    struct timeval tim;
    struct rusage ru;
    getrusage(RUSAGE_SELF, &ru);
    tim = ru.ru_utime;
    double t = (double)tim.tv_sec / 1000.0;
    return t;
}

【问题讨论】:

    标签: time system timer unix


    【解决方案1】:

    不应该是 tim.tv_sec * 1000.0 + tim.tv_usec/1000.0 转换为毫秒吗?您将 tim.tv_sec 除以 1000,因此如果您的运行时间低于 1000 秒,您将获得 0 的返回值。

    【讨论】:

    • 是的,我同意吉姆的观点。使用正确的转换,否则返回值为零。
    【解决方案2】:

    在每个函数中,更改为: double t = (double)tim.tv_sec*1000.0 + tim.tv_usec/1000.0;

    不要忘记包含sys/resource.h

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2021-02-11
      • 2013-08-26
      • 2013-11-13
      • 2011-05-17
      • 1970-01-01
      • 2011-08-15
      • 2015-07-04
      相关资源
      最近更新 更多