clock() 函数用来获得自程序运行以来所消耗的系统时钟数。函数声明如下:
[C++] 纯文本查看 复制代码
#include <time.h>
clock_t clock(void);
函数的返回值是 clock_t 类型,实际上是 long long 类型,在 32 位机上以 64 位的长度表示。
该时间并不是从表面上看程序从运行到结束时所耗费的时间,如下面程序:
[C++] 纯文本查看 复制代码
#include <stdio.h>
#include <time.h>
int main()
{
printf ("ticks:%lld\n", clock());
sleep (5);
printf ("ticks:%lld\n", clock());
return 0;
}
运行输出:$ ./clock
ticks:577732307436175360
ticks:577732307436175360 由上可见,即使在程序中 sleep() 了 5 秒后,前后两个时间并没有变化。这是因为,在执行 sleep() 函数时,该进程会被系统置于休眠状态,这时候程序是没有在运行的,而 clock() 获得是程序真正运行时所耗费的时间,所以上面输出中的前后两个时间并没有变化。
另外,对于 clock() 输出,可以除以一个常数 CLOCKS_PER_SEC 用以获得秒数,在 32 位的系统上,该常数为 1,000,000 。
下面用一个计时器的例子演示 clock() 的用法:
[C++] 纯文本查看 复制代码
#include <stdio.h>
#include <time.h>
int main()
{
int seconds = 5;
clock_t ticks;
ticks = clock();
printf ("%lld\n", ticks/CLOCKS_PER_SEC);
while((clock()/CLOCKS_PER_SEC - ticks/CLOCKS_PER_SEC) < seconds);
printf ("elapsed time:%d\n", clock()/CLOCKS_PER_SEC - ticks/CLOCKS_PER_SEC);
printf ("\a");
return 0;
}
运行输出:$ ./clock
5091074385217847296
elapsed time:5 上面程序中,设定闹铃时间为 5 秒,程序一直在循环等待并倒计时。时间到后闹铃,然后输出逝去的时间。因为现在的 CPU 都比较快,一般的在到达闹铃时间后再次调用一次 clock() 函数不会造成 1 秒得时间跨越。 |