首页 > 代码库 > C/C++之时间差计算
C/C++之时间差计算
1、clock函数
C/C++中的计时函数是clock(),而与其相关的数据类型是clock_t。
在MSDN中,查得对clock函数定义如下: clock_t clock( void ); 这个函数返回从“开启这个程序进程”到“程序中调用clock()函数”时之间的CPU时钟计时单元(clock tick)数,在MSDN中称之为挂钟时间(wal-clock)。其中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。
在如下所示的代码中,并不会输出一个超过3s的值,而是CPU的计算时间。
void test_clock(){ long i = 60000000L; clock_t start, finish; double duration; double a; start = clock(); printf( "Delay for 3 seconds\n" ); sleep(3); printf( "Done!\n" ); while( i-- ) { a = sqrt(sqrt(16.0)); a = sqrt(sqrt(16.0)); } printf( "Done!\n" ); finish = clock(); duration = (double)(finish - start) / CLOCKS_PER_SEC; printf( "Total elapsed %lf seconds\n", duration); }
2、time函数
C语言函数difftime
功 能:返回两个time_t型变量之间的时间间隔,即 计算两个时刻之间的时间差。
用 法: double difftime(time_t time2, time_t time1);
头文件:time.h
void test_difftime(){ time_t first, second; first = time(NULL); sleep(3); second = time(NULL); printf("The difference is: %f seconds\n",difftime(second,first));}
在程序中对函数计算运行的时间差,应该用difftime方法。
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。