频道栏目
首页 > 程序开发 > 软件开发 > C语言 > 正文
C语言time.h中clock()函数测程序运行时间的方法
2017-09-30 14:33:46         来源:mengxiangjia_linxi的博客  
收藏   我要投稿

C语言中求程序执行的时间可以使用clock()函数

_CRTIMP clock_t __cdecl __MINGW_NOTHROW clock (void);(可以把它直接视为clock_t clock(void);)

这个函数返回从“开启这个程序进程”到“程序中调用clock()函数”时之间的CPU时钟计时单元(clock tick)数,其中clock_t是用来保存时间的数据类型,

在time.h文件中,我们可以找到对它的定义:

#ifndef _CLOCK_T_DEFINED  
typedef long clock_t;  
#define _CLOCK_T_DEFINED  
#endif  

很明显,clock_t是一个长整形数。在time.h文件中,还定义了一个常量CLOCKS_PER_SEC,它用来表示一秒钟会有多少个时钟计时单元,其定义如下:

#define CLOCKS_PER_SEC ((clock_t)1000)  

可以看到每过千分之一秒(1毫秒),调用clock()函数返回的值就加1。
下面给出一个示例:

#include   
#include   
#include   

int main()  
{  
    long i=10000000L;  
    clock_t start,finish;  
    double TheTimes;  
    printf("做%ld次空循环需要的时间为",i);  
    start=clock();  
    while(i--);  
    finish=clock();  
    TheTimes=(double)((finish-start)/CLOCKS_PER_SEC);  
    printf("%f秒。\n",TheTimes);  
    return 0;  
} 

可是运行完每次的结果都为:

做10000000次空循环需要的时间为0.000000秒。  

Process returned 0 (0x0)   execution time : 0.438 s  
Press any key to continue. 

加大循环次数也不行。
最后终于找到的问题所在:

#include   
#include   
#include   

int main()  
{  
    long i=10000000L;  
    clock_t start,finish;  
    double TheTimes;  
    printf("做%ld次空循环需要的时间为",i);  
    start=clock();  
    while(i--);  
    finish=clock();  
    TheTimes=(double)(finish-start)/CLOCKS_PER_SEC; //红色语句
    printf("%f秒。\n",TheTimes);  
    return 0;  
}  

看红色行和上面的区别,现在明白了吧!是由于括号运算符改变了运算的优先级,将里面的四则运算变成了整数之间的除法,造成位数被舍去,造成的误差。

看来细节还是很重要的。

写出来和大家分享。

点击复制链接 与好友分享!回本站首页
上一篇:C语言中scanf的操作代码
下一篇:c语言中如何将数组初始化为0?
相关文章
图文推荐
点击排行

关于我们 | 联系我们 | 广告服务 | 投资合作 | 版权申明 | 在线帮助 | 网站地图 | 作品发布 | Vip技术培训 | 举报中心

版权所有: 红黑联盟--致力于做实用的IT技术学习网站