localtime_r 返回值不对,请求解救

haiyaguixin 2015-08-13 06:48:11
代码如下:
struct tm pkt_time = {0};
static char ts[MAX_TIME_LEN];
time_t timep = 1439460264;
localtime_r(&timep , &pkt_time);// 这个函数貌似有些问题
strftime(ts, MAX_TIME_LEN, "%Y-%m-%d %H:%M:%S", &pkt_time);

printf("%d %d %d %d %d %d\n ", pkt_time.tm_sec, pkt_time.tm_min, pkt_time.tm_hour, pkt_time.tm_mday, pkt_time.tm_mon, pkt_time.tm_year);

printf("---- ts %u %s\n", pack->time_, ts);

程序运行后,打印出来的是:
38 13 9 0 0 493407503
---- ts 1439462109 493409403-01-00 09:13:38

明显不对啊, 求解救难道 是多线程引起的, 貌似 说 localtime_r 是线程安全的啊
...全文
621 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
haiyaguixin 2015-08-13
  • 打赏
  • 举报
回复
引用 3 楼 guyuguang8628391 的回复:
可能是系统设置的问题。
你好,详细的说下看看
haiyaguixin 2015-08-13
  • 打赏
  • 举报
回复
服务器上代码是这样的: void ComsumerWorker::writeToFile(HttpPack* pack) { assert(pack); static char logStr[4096]; struct tm pkt_time = {0}; static char ts[MAX_TIME_LEN]; static char saddr[INET6_ADDRSTRLEN]; static char daddr[INET6_ADDRSTRLEN]; FILE* fp = fopen(GLOBAL_CONFIG::LOG_FILE, "a+"); assert(fp); tm* ret = localtime_r((time_t *) &pack->time_, &pkt_time);// 杩.釜?芥.璨.技?.??.? strftime(ts, MAX_TIME_LEN, "%Y-%m-%d %H:%M:%S", &pkt_time); printf("%d %d %d %d %d %d\n ", pkt_time.tm_sec, pkt_time.tm_min, pkt_time.tm_hour, pkt_time.tm_mday, pkt_time.tm_mon, pkt_time.tm_year); printf("---- ts %u %s\n", pack->time_, ts); int af = (pack->is_ipv4_ == 1) ? AF_INET : AF_INET6; 真看不出有什么问题啊
图灵转世 2015-08-13
  • 打赏
  • 举报
回复
可能是系统设置的问题。
haiyaguixin 2015-08-13
  • 打赏
  • 举报
回复
引用 楼主 haiyaguixin 的回复:
代码如下: struct tm pkt_time = {0}; static char ts[MAX_TIME_LEN]; time_t timep = 1439460264; localtime_r(&timep , &pkt_time);// 这个函数貌似有些问题 strftime(ts, MAX_TIME_LEN, "%Y-%m-%d %H:%M:%S", &pkt_time); printf("%d %d %d %d %d %d\n ", pkt_time.tm_sec, pkt_time.tm_min, pkt_time.tm_hour, pkt_time.tm_mday, pkt_time.tm_mon, pkt_time.tm_year); printf("---- ts %u %s\n", pack->time_, ts); 程序运行后,打印出来的是: 38 13 9 0 0 493407503 ---- ts 1439462109 493409403-01-00 09:13:38 明显不对啊, 求解救难道 是多线程引起的, 貌似 说 localtime_r 是线程安全的啊
引用 1 楼 JiangWenjie2014 的回复:
没问题

#include <stdio.h>
#include <time.h>

int main ()
{
    char timestr[128];

    time_t now = /* time (0) */1439460264;
    struct tm tm_now;

    localtime_r (&now, &tm_now);
    strftime (timestr, sizeof (timestr), "%Y-%m-%d %H:%M:%S", &tm_now);

    printf ("%s\n", timestr);

    return 0;
}
打印出来的是 2015-08-13 18:04:24
我在我自己的虚拟机上 是对的, 但是在服务器上就是错的
JiangWenjie2014 2015-08-13
  • 打赏
  • 举报
回复
没问题

#include <stdio.h>
#include <time.h>

int main ()
{
    char timestr[128];

    time_t now = /* time (0) */1439460264;
    struct tm tm_now;

    localtime_r (&now, &tm_now);
    strftime (timestr, sizeof (timestr), "%Y-%m-%d %H:%M:%S", &tm_now);

    printf ("%s\n", timestr);

    return 0;
}
打印出来的是 2015-08-13 18:04:24
资源下载链接为: https://pan.quark.cn/s/d9ef5828b597 在C#开发中,时间处理是常见需求。timeGetTime()、time(NULL)和localtime是与时间相关的函数,它们各有特点和用途。 timeGetTime() timeGetTime()是Windows API函数,返回自1601年1月1日以来的毫秒数,返回值为DWORD类型(无符号32位整数),最大范围约49.7天。它主要用于计算时间间隔,不考虑时区和夏令时,是一个连续的时间计数器。 time(NULL) 在C#中,没有直接的time(NULL)函数,但DateTime.Now与之类似,用于获取当前系统时间。time(NULL)是C/C++标准库函数,返回自1970年1月1日(UTC)以来的秒数,类型为time_t。该值可用于创建、比较或操作日期和时间,并可通过localtime或gmtime转换为易读格式。 localtime localtime来自C/C++标准库,接受time_t类型的指针,将其转换为包含本地时间各部分(如年、月、日、时、分、秒)的tm结构体。它会考虑时区和夏令时,返回用户所在地区的当前时间。在C#中,DateTime.ToLocalTime()可实现类似功能,但通常不必要,因为DateTime.Now默认就是本地时间。 总结来说,这三个函数的主要区别在于: timeGetTime()提供自特定起点以来的毫秒级时间戳,适用于计算时间差。 time(NULL)(C#中对应DateTime.Now)返回自1970年以来的秒级时间戳,用于获取当前系统时间,并可进一步转换为易读格式。 localtimetime_t时间戳转换为本地时间结构体,便于处理和显示日期和时间。 在实际项目中,开发者需根据需求选择合适的时间处理函数。例如,需要精确到毫秒的计时,可选择

23,223

社区成员

发帖
与我相关
我的任务
社区描述
Linux/Unix社区 应用程序开发区
社区管理员
  • 应用程序开发区社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧