Sdílet prostřednictvím


difftime, _difftime32, _difftime64

Vyhledá rozdíl mezi dvěma časy.

double difftime( 
   time_t timer1,
   time_t timer0 
);
double _difftime32( 
   __time32_t timer1,
   __time32_t timer0 
);
double _difftime64( 
   __time64_t timer1,
   __time64_t timer0 
);

Parametry

  • timer1
    Koncový čas.

  • timer0
    Čas začátku.

Vrácená hodnota

difftimeVrátí uplynulý čas v sekundách od timer0 na timer1.Vrácená hodnota je číslo s plovoucí desetinnou čárkou, dvojitá přesnost.Vrácená hodnota může být 0, označující chybu.

Poznámky

difftime Funkce vypočítá rozdíl mezi dvěma hodnotami zadaný čas timer0 a timer1.

Předaná hodnota času musí přizpůsobit v rozsahu od time_t.time_tje hodnota 64-bit.Konec rozsahu byl tedy rozšířen z 03: 14: 07 01.01.08 19 do 31. prosince 3000 23: 59: 59.Nižší rozsah time_t je stále půlnoci 1. ledna 1970.

difftimevložené funkce, který je vyhodnocen buď je _difftime32 nebo _difftime64 v závislosti na tom, zda _USE_32BIT_TIME_T je definován._difftime32 a _difftime64 lze přímo vynutit použití určité velikosti, typu času.

Tyto funkce ověřit jejich parametrů.Pokud parametrů je nulové nebo záporné, parametr neplatný popisovač je vyvolána, jak je popsáno v Ověření parametrů.Pokud je povoleno spuštění pokračovat, vrátí tyto funkce hodnotu 0 a errno na EINVAL.

Požadavky

Rutina

Požadované záhlaví

difftime

<time.h>

_difftime32

<time.h>

_difftime64

<time.h>

Další informace o kompatibilitě, viz Compatibility v úvodu.

Příklad

// 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 );
}
  
  
  

Ekvivalent v rozhraní .NET Framework

System::datetime:: odečíst

Viz také

Referenční dokumentace

Podpora s plovoucí desetinnou čárkou

Aplikace Správa času

time, _time32, _time64