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 種類の指定された時刻値 timer0 と timer1間の相違点を計算します。
指定した時刻値は time_t範囲内に収まる必要があります。 time_t は 64 ビット値です。 したがって、範囲の末尾は 03:14 から拡張されました: 1 年 1 月 07 日 19 日 23:59: 2038 年に59、3000 12 年 5 月 31 日。 time_t の下部の範囲は、午前 1970 (1 年 12 月 1 日です。
difftime は _USE_32BIT_TIME_T が定義されているかどうか _difftime32 または _difftime64 に評価されるインライン関数です。_difftime32 と_difftime64 は時刻型の特定の数の使用を強制的に直接使用できます。
これらの関数では、パラメーターの検証が行われます。 パラメーターの数は負のの場合、無効なパラメーター ハンドラーが パラメーターの検証"に説明されているように、呼び出されます。 実行の継続が許可された場合、これらの関数は 0 を返し、EINVALに errno を設定します。
必要条件
ルーチン |
必須ヘッダー |
---|---|
difftime |
<time.h> |
_difftime32 |
<time.h> |
_difftime64 |
<time.h> |
互換性の詳細については、「C ランタイム ライブラリ」の「互換性」を参照してください。
使用例
// 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 );
}