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_t64 비트 값이입니다.따라서, 범위의 끝 03시 14분: 07에서 2038 년 1 월 19 일 23시 59분: 59로, 3000 년 12 월 31 확장 되었습니다.낮은 범위를 time_t 는 1970 년 1 월 1 일 자정입니다.
difftime수를 계산 하는 인라인 함수 이며 _difftime32 또는 _difftime64 여부에 따라 _USE_32BIT_TIME_T 정의 됩니다.직접 강제로 사용 시간 형식의 특정 크기의 _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 );
}