曲径通幽论坛

 找回密码
 立即注册
搜索
查看: 4682|回复: 0
打印 上一主题 下一主题

[时间相关] clock() -- 获得程序的 CPU 时间

[复制链接]

4918

主题

5880

帖子

3万

积分

GROAD

曲径通幽,安觅芳踪。

Rank: 6Rank: 6

积分
34395
跳转到指定楼层
楼主
发表于 2011-8-14 14:10:43 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
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 秒得时间跨越。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|曲径通幽 ( 琼ICP备11001422号-1|公安备案:46900502000207 )

GMT+8, 2025-5-3 23:36 , Processed in 0.062782 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表