![](/img/trans.png)
[英]Measuring amount of CPU time taken by a piece of code, in C on Unix/Linux
[英]Measuring time taken by an exec()-ed process on linux
我正在使用times()函數測量值,但不確定我的方法是否正確。 請看看和建議
struct tms tms_start, tms_end;
if (!(pid=fork()))
{
//some necessary operations here
times(&tms_start);
execl(...);
}
else if (pid)
{
//in parent
int status;
wait(&status);
times(&tms_end);
if (WIFEXITED(status))
{
if(WEXITSTATUS(status)==0)
{
clock_t real = tms_end.tms_cstime - tms_start.tms_stime
float running_time = real/(double)sysconf(_SC_CLK_TK);
}
}
}
您需要在調用fork()
之前先調用times(&tms_start)
fork()
。 在上面的代碼中, tms_start
變量在父級中未初始化,因為父級從不調用times(&tms_start)
。
struct tms tms_start, tms_end;
times(&tms_start); // <-- here
if (!(pid=fork()))
{
//some necessary operations here
execl(...);
}
else if (pid)
{
...
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.