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 位值。 因此,该范围的末尾自 03:14 扩展: 一月 07 日 19 日 2038 年到 23:59: 59, 3000 年十二月 31 日,。 time_t 的下半部分范围午夜, 1970 年一月 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 );
}
        

.NET Framework 等效项

系统:: datetime:: 相减

请参见

参考

浮点支持

时间线

time, _time32, _time64