localtime()使用陷阱及解决方法(localtime()连续使用问题)

函数简介

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的,无论你是定义的还是强转的。

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值