函数简介
C 库函数 struct tm *localtime(const time_t *timer) 使用 timer 的值来填充 tm 结构。timer 的值被分解为 tm 结构,并用本地时区表示。
该函数返回指向 tm 结构的指针,该结构带有被填充的时间信息。下面是 tm 结构的细节
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; /* 夏令时 */
};
正常用法
int main ()
{
time_t rawtime;
struct tm *info;
char buffer[80];
time( &rawtime );
info = localtime( &rawtime );
printf("当前的本地时间和日期:%s", asctime(info));
return(0);
}
结果:
当前的本地时间和日期:2019-12-20 11:04:42
坑用法
例2:
#include <stdio.h>
#include <time.h>
int main ()
{
int ultime1=1576811082;
int ultime2=ultime1-900;
struct tm *info1;
struct tm *info2;
char buffer[80];
info1 = localtime( &ultime1 );
info2 = localtime( &ultime2 );
printf("当前的本地时间和日期:%s", asctime(info1));
printf("当前的本地时间和日期:%s", asctime(info2));
return(0);
}
结果:
当前的本地时间和日期:2019-12-20 11:04:42
当前的本地时间和日期:2019-12-20 11:04:42
坑1:连续使用localtime()
连续使用localtime()的结果就是返回相同的时间,不会得到你想要的两个不同的时间。
原因:localtime()返回id指针会指向同一个区域,所以你不管调几次都是返回该指针指向的区域,不会变的。有人说把返回值赋给其他变量再调用localtime()可以解决该问题。。。。嗯。。实际验证是不行的。
解决方式:使用localtime_r()函数。据说localtime()是线程不安全的,而localtiem_r()是线程安全的。
坑2:用int这个类型,代替了time_t类型
比如我的例2。通常你不会得到你想要的值,尤其需要的是转换成字符串的值。调试时时间戳是对的,但是使用转换时间格式的函数后就会是一个特别不靠谱的时间。
原因:就是定义的数据类型问题。time_t是64位的,int是32位的,而localtime()的入参是个地址。我们虽然不知道localtime()具体都干啥了,但是从结果来看,localtime()的某些处理过程一定是跟入参的位数相关的。
解决方式:localtime()的入参一定要是time_t的,无论你是定义的还是强转的。