C 库函数 - mktime()


描述

C 库函数 time_t mktime(struct tm *timeptr)timeptr 所指向的结构转换为一个依据本地时区的 time_t 值。

声明

下面是 mktime() 函数的声明。

  1. time_t mktime(struct tm *timeptr)

参数

  • timeptr -- 这是指向表示日历时间的 time_t 值的指针,该日历时间被分解为以下各部分。下面是 timeptr 结构的细节:
  1. struct tm {
  2. int tm_sec; /* 秒,范围从 0 到 59 */
  3. int tm_min; /* 分,范围从 0 到 59 */
  4. int tm_hour; /* 小时,范围从 0 到 23 */
  5. int tm_mday; /* 一月中的第几天,范围从 1 到 31 */
  6. int tm_mon; /* 月份,范围从 0 到 11 */
  7. int tm_year; /* 自 1900 起的年数 */
  8. int tm_wday; /* 一周中的第几天,范围从 0 到 6 */
  9. int tm_yday; /* 一年中的第几天,范围从 0 到 365 */
  10. int tm_isdst; /* 夏令时 */
  11. };

返回值

该函数返回一个 time_t 值,该值对应于以参数传递的日历时间。如果发生错误,则返回 -1 值。

实例

下面的实例演示了 mktime() 函数的用法。

  1. #include <stdio.h>
  2. #include <time.h>
  3.  
  4. int main ()
  5. {
  6. int ret;
  7. struct tm info;
  8. char buffer[80];
  9.  
  10. info.tm_year = 2001 - 1900;
  11. info.tm_mon = 7 - 1;
  12. info.tm_mday = 4;
  13. info.tm_hour = 0;
  14. info.tm_min = 0;
  15. info.tm_sec = 1;
  16. info.tm_isdst = -1;
  17.  
  18. ret = mktime(&info);
  19. if( ret == -1 )
  20. {
  21. printf("错误:不能使用 mktime 转换时间。\n");
  22. }
  23. else
  24. {
  25. strftime(buffer, sizeof(buffer), "%c", &info );
  26. print(buffer);
  27. }
  28.  
  29. return(0);
  30. }

让我们编译并运行上面的程序,这将产生以下结果:

  1. Wed Jul 4 00:00:01 2001