您的位置:首页 > 其它

分析localtime返回值造成的一个bug

2010-10-22 15:18 405 查看
最近写了下面的代码

time_t _time = (time_t)lastUpdTime;;//lastUpdTime从某处加载的
tm *tptime = localtime(&_time);

time_t now;
time(&now);
tm* tmptime = localtime(&now);

int32 day = tmptime->tm_yday - tptime->tm_yday;

if(day >= 1)

{

...

}

上面代码出现的bug就是 if( day>=1 )这个条件从来不为真,然后我就调试跟踪了下发现day的值每次是0,再仔细一瞧发现 tmptime和tptime的地址竟然是一样的,所以这两个从来都是相等的,然后网上查了下资料关于localtime的返回值说明

The four functions asctime(), ctime(), gmtime() and localtime() return a pointer to static data and hence are not thread-safe. Thread-safe versions asctime_r(), ctime_r(), gmtime_r() and localtime_r() are specified by SUSv2, and available since libc 5.2.5.

原来localtime返回的是静态数据段,难怪了,要安全点还是用 localtime_r为好,就是麻烦点

The localtime_r() function does the same, but stores the data in a user-supplied struct

需要自己申请和释放内存了

其实仔细想想localtime的用法应该就能猜测出来,返回一个指针,而且不需要自己管理内存,基本上是静态数据差不离了,有些还不是不要想当然的好
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: