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비트 값입니다. 따라서, 범위의 끝은 2038년 1월 19일 03:14:07에서 3000년 12월 31일 23:59:59으로 확장되었습니다. time_t의 낮은 범위는 1970년 1월 1일 자정입니다.
difftime은 _USE_32BIT_TIME_T이 정의되었는지의 여부에 따라 _difftime32 또는 _difftime64 중 하나를 계산하는 인라인 함수입니다. _difftime32 및 _difftime64는 시간 형식의 특정 크기의 사용을 직접 사용하도록 할 수 있습니다.
이러한 함수는 해당 함수 매개 변수의 유효성을 검사합니다. 매개 변수가 0 또는 음수인 경우, 매개 변수 유효성 검사 설명된대로 잘못된 매개 변수 처리기가 호출됩니다. 계속해서 실행하도록 허용된 경우, 이러한 함수는 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 );
}