difftime _difftime32, _difftime64
Localiza a diferença entre dois horários.
double difftime(
time_t timer1,
time_t timer0
);
double _difftime32(
__time32_t timer1,
__time32_t timer0
);
double _difftime64(
__time64_t timer1,
__time64_t timer0
);
Parâmetros
timer1
time de término.timer0
time de início.
Valor de retorno
difftime Retorna o time decorrido em segundos, de timer0 para timer1. O valor retornado é um número de ponto flutuante de precisão dupla.O valor retornado pode ser 0, indicando um erro.
Comentários
The difftime função calcula a diferença entre os dois valores de time fornecido timer0 e timer1.
O valor temporal fornecido deve caber dentro do intervalo de time_t. In Visual C++ 2005, time_t é um valor de 64 bit. Assim, o participante do intervalo foi estendido de 14: 03: 07 19 de janeiro de 2038 para 23: 59: 59, 31 de dezembro de 3000.O menor intervalo de time_t ainda é meia-noite, 1 º de janeiro de 1970.
In Visual C++ 2005, difftime é uma função in-line que é avaliada como um _difftime32 ou _difftime64 Dependendo se _USE_32BIT_TIME_T está definido. _difftime32 e _difftime64 podem ser usados diretamente para forçar o uso de um determinado dimensionar do tipo time.
Essas funções validar seus parâmetros.Se o dos parâmetros é zero ou negativos, o manipulador de parâmetro inválido é invocado, sistema autônomo descrito em Validação de parâmetro. Se a execução for permitida para continuar, essas funções retornam 0 e conjunto errno para EINVAL.
Requisitos
Rotina |
Cabeçalho necessário |
---|---|
difftime |
<time.h> |
_difftime32 |
<time.h> |
_difftime64 |
<time.h> |
Para obter informações adicionais compatibilidade, consulte Compatibilidade na introdução.
Exemplo
// crt_difftime.c
// This program calculates the amount of time
// needed to do a floating-point multiply 500 million times.
//
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
int main( void )
{
time_t start, finish;
long loop;
double result, elapsed_time;
printf( "Multiplying 2 floating point numbers 500 million times...\n" );
time( &start );
for( loop = 0; loop < 500000000; loop++ )
result = 3.63 * 5.27;
time( &finish );
elapsed_time = difftime( finish, start );
printf( "\nProgram takes %6.0f seconds.\n", elapsed_time );
}
Multiplying 2 floating point numbers 500 million times... Program takes 5 seconds.