我只是编写 ac 程序以每隔一秒打印一次整数值作为练习,该程序在打印下一个整数之前等待一秒钟后打印整数,因此程序需要 5 秒才能完成执行。我正在使用clock_t
和time()
作为计时器和它可以工作,但是当我使用clock_t
它clock
作为计时器时它不起作用。
据我所知time_t
,time()
是绝对时间,使用自 1970 年以来经过的秒数。clock_t
而clock()
使用自程序运行以来的时间。
这是第一个使用time_t
andtime(NULL)
#include <stdio.h>
#include <time.h>
int main (void) {
int i;
int sec=1;
time_t start,end;
start=time(NULL);
for(i=1;i<=5;i++){
time_t wait=sec+time(NULL);
while(time(NULL) < wait) {}
printf("%d\n",i);
}
end=time(NULL);
printf("program take %d second\n",(unsigned int)difftime(end,start));
return 0;
}
这是程序运行时的结果:
1
2
3
4
5
program take 5 second
程序的执行准确地每隔一秒打印一次整数,或者在打印下一个整数之前等待一秒
这是第二个使用clock_t
andclock()
#include <stdio.h>
#include <time.h>
int main (void) {
int sec=1;
int i;
clock_t start,end;
start=clock();
for(i=1;i<=5;i++){
clock_t wait=sec*CLOCKS_PER_SEC;
while(clock ()<wait){}
printf("%d\n",i);
}
end=clock();
printf("the program take %lf second\n",(double)(end-start)/CLOCKS_PER_SEC);
return 0;
}
这是第二个程序使用clock_t
和的结果clock()
1
2
3
4
5
the program take 0.998901 second
并且在执行之后它不会每秒钟打印一次,而是首先等待一秒钟然后打印所有整数,而不是在打印下一个整数之前等待一秒钟。
请解释第二个程序发生了什么以及 time() 和 clock() 函数之间究竟有什么区别?