我是靠谱客的博主 神勇电灯胆,最近开发中收集的这篇文章主要介绍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 secondsn" );
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 secondsn", 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 secondsn",difftime(second,first));
}

在程序中对函数计算运行的时间差,应该用difftime方法。

 

转载于:https://www.cnblogs.com/erli11/p/3873063.html

最后

以上就是神勇电灯胆为你收集整理的C/C++之时间差计算的全部内容,希望文章能够帮你解决C/C++之时间差计算所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(41)

评论列表共有 0 条评论

立即
投稿
返回
顶部