C/C++如何以秒计时程序运行时间

转自: https://blog.csdn.net/FX677588/article/details/65445554


C/C++中计时调用的方法函数是clock()函数,它定义在ctime或者time.h头文件中。形式如下:

_CRTIMP clock_t __cdecl __MINGW_NOTHROW clock (void);

一般情况下可以把它直接视为clock_t clock(void);其中函数的返回值是clock_t。clock_t实质是头文件中long数据类型类型定义的一个代称。使用计时很简单,只要在程序想计时的地方放入一个clock()函数,另外在结束地方放置一个clock()函数,两个返回值的差即是程序消耗时间。但是该函数计时是以毫秒(ms)为单位的,也就是没过千分之一秒加一,所以需要除以一个常量1000才是以秒计时的,一般使用头文件中声明好的常量CLOCKS_PRE_SEC(即1000)。程序如下:

#include
int main()
{
 clock_t start = clock();
 //.....程序主体
 clock_t finish = clock();
 double consumeTime = (double)(finish-start)/CLOCKS_PER_SEC;//注意转换为double的位置
}

上面程序需要注意强制转换double的位置,如果不转换得到的结果都是整型,而放置在整个右表达式前面也是没有效果的,还是整型。这样转换的好处就是可以精确到小数以后,不足一秒钟的时间就不会结果为0。

你可能感兴趣的:(C/C++)