difftime, _difftime32, _difftime64
Находит разность между 2 временем.
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 вычисляет разницу между 2 и timer1 предоставленными значениями времени timer0.
Предоставленное значение времени должно по размерам диапазон time_t.time_t значение 64.Таким образом, конец диапазона был расширен от 03:14: 7-ое января 19 2038 23:59: 59 - 31-ое декабря 3000.Более низкое диапазон time_t по-прежнему полуночно 1-ое января 1970.
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 );
}