您好,我遇到了一个小问题,在为我的OS类的项目工作。我被指示使用getrusage()来确定我正在编写的程序在用户模式和内核模式下所花费的时间。问题是它总是告诉我我的CPU和内核使用率为零。在查找该函数时,手册页提到,如果您的特定linux版本不支持rusage结构的某些成员,则将它们设置为零。基本上,我想知道是否有人可以告诉我,我调用函数和访问它的参数是否正确(这样我就可以知道我是不是问题所在,或者我的内核不支持这些功能)。
代码
struct rusage usage;
struct rusage *p = &usage;
getrusage(RUSAGE_SELF, p);
printf("time in user mode = %ld\ntime in kernel mode = %ld\n", p->ru_utime.tv_sec, p->ru_stime.tv_sec);发布于 2012-04-16 10:40:25
struct rusage成员ru_utime和ru_stime都是struct timeval类型,如下所示:
struct timeval {
time_t tv_sec; /* seconds */
suseconds_t tv_usec; /* microseconds */
};tv_sec告诉您经过的秒数,tv_usec告诉您剩余的微秒数。因此,如果您想打印出整个时间值,则需要同时打印这两个值。
因为您只打印tv_sec成员,所以我怀疑您的程序运行的时间不足以超过0秒。您还需要打印other values
printf("time in user mode = %ld.%06ld ",
p->ru_utime.tv_sec, p->ru_utime.tv_usec);
printf("time in kernel mode = %ld.%06ld\n",
p->ru_stime.tv_sec, p->ru_stime.tv_usec);您可以查看the question I linked,了解打印timeval结构的其他方法。
https://stackoverflow.com/questions/10168109
复制相似问题