Latest web development tutorials

Cライブラリ関数 - はmktime()

C標準ライブラリ -  <TIME.H> C標準ライブラリ- <TIME.H>

説明

ローカルタイムゾーンに基づいて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

C標準ライブラリ -  <TIME.H> C標準ライブラリ- <TIME.H>