difftime、_difftime32、_difftime64
查找两个集之间的差异。
double difftime(
time_t timer1,
time_t timer0
);
double _difftime32(
__time32_t timer1,
__time32_t timer0
);
double _difftime64(
__time64_t timer1,
__time64_t timer0
);
参数
timer1
结束时间。timer0
开始时间。
返回值
difftime 返回从 timer0 到 timer1的运行时间(单位:秒)。 返回双精度浮点数字的值。 返回值可能为 0,表示错误。
备注
difftime 函数计算两个提供的时间值timer0 和 timer1之间的差异。
提供的时间的值必须在 time_t范围内。 time_t是64 位值。 因此,范围的结束自19 日到 2038 年 1 月 19 日扩展到3000 年 12 月 31 日 23:59:59。 time_t的低位范围还是 1970 年 1 月 1 日。
difftime 是计算_difftime32 或 _difftime64的内联函数,这取决于是否定义了 _USE_32BIT_TIME_T。_difftime32 和_difftime64 可直接用于强制特殊时间类型的范围。
这些函数验证其参数。 如果参数为零或负值,则调用无效参数处理程序,如 参数验证所述。 如果允许执行继续,则这些函数返回0,并将errno 设置为 EINVAL 。
要求
例程 |
必需的标头 |
---|---|
difftime |
<time.h> |
_difftime32 |
<time.h> |
_difftime64 |
<time.h> |
有关其他兼容性信息,请参见“简介”中的兼容性。
示例
// crt_difftime.c
// This program calculates the amount of time
// needed to do a floating-point multiply 100 million times.
//
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <float.h>
double RangedRand( float range_min, float range_max)
{
// Generate random numbers in the half-closed interval
// [range_min, range_max). In other words,
// range_min <= random number < range_max
return ((double)rand() / (RAND_MAX + 1) * (range_max - range_min)
+ range_min);
}
int main( void )
{
time_t start, finish;
long loop;
double result, elapsed_time;
double arNums[3];
// Seed the random-number generator with the current time so that
// the numbers will be different every time we run.
srand( (unsigned)time( NULL ) );
arNums[0] = RangedRand(1, FLT_MAX);
arNums[1] = RangedRand(1, FLT_MAX);
arNums[2] = RangedRand(1, FLT_MAX);
printf( "Using floating point numbers %.5e %.5e %.5e\n", arNums[0], arNums[1], arNums[2] );
printf( "Multiplying 2 numbers 100 million times...\n" );
time( &start );
for( loop = 0; loop < 100000000; loop++ )
result = arNums[loop%3] * arNums[(loop+1)%3];
time( &finish );
elapsed_time = difftime( finish, start );
printf( "\nProgram takes %6.0f seconds.\n", elapsed_time );
}