Cライブラリ関数 - はmktime()
説明
ローカルタイムゾーンに基づいてtime_tの値に尖った構造をtimeptrするのtime_tはmktime(構造体tm * timeptr)Cライブラリ関数。
声明
ここではmktime()関数の宣言です。
time_t mktime(struct tm *timeptr)
パラメータ
- timeptr -これはカレンダー時間のtime_tのカレンダー時刻表現を指し示すポインタ値は、次のセクションに分割されています。ここでは構造timeptrの詳細は以下のとおりです。
struct tm { int tm_sec; /* 秒,范围从 0 到 59 */ int tm_min; /* 分,范围从 0 到 59 */ int tm_hour; /* 小时,范围从 0 到 23 */ int tm_mday; /* 一月中的第几天,范围从 1 到 31 */ int tm_mon; /* 月份,范围从 0 到 11 */ int tm_year; /* 自 1900 起的年数 */ int tm_wday; /* 一周中的第几天,范围从 0 到 6 */ int tm_yday; /* 一年中的第几天,范围从 0 到 365 */ int tm_isdst; /* 夏令时 */ };
戻り値
この関数は、カレンダー時間のパラメータの受け渡しに対応するtime_tの値を返します。 エラーが発生した場合には、-1の値を返します。
例
次の例では、はmktime()関数が使用されている示しています。
#include <stdio.h> #include <time.h> int main () { int ret; struct tm info; char buffer[80]; info.tm_year = 2001 - 1900; info.tm_mon = 7 - 1; info.tm_mday = 4; info.tm_hour = 0; info.tm_min = 0; info.tm_sec = 1; info.tm_isdst = -1; ret = mktime(&info); if( ret == -1 ) { printf("错误:不能使用 mktime 转换时间。\n"); } else { strftime(buffer, sizeof(buffer), "%c", &info ); print(buffer); } return(0); }
それでは、以下になります上記のプログラムを、コンパイルして実行してみましょう:
Wed Jul 4 00:00:01 2001