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 是线程安全的啊
...全文
604 5 打赏 收藏 转发到动态 举报
AI 作业
写回复
用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
访问真八字排盘系统介绍: 1、八字排盘 八字排盘是将年月日时按照天干地支的形式进行排列,一个时间单位代表了一个柱。八字由年柱、月柱、日柱和时柱共四个柱组成,也被称为四柱八字。八字学中基于中国阴阳五行、天干地支与刑冲克害、以及民间盲派的神煞论等方式,进一步预测爱情顺遂、工作高低、姻缘好坏、财富高低、学业成就、身体健康等事的学问。 八字排盘由以下元素组合:年月日时四柱、大运干支、胎元 、流年干支、十神、地势、神煞等。生辰八字不只是把干支历计算出来,而还要遵守月令、节令的强弱,时辰的阴阳变化进行校正。排盘分析,就是根据出生者的性别、天干地支的阴阳五行关系、进一步推算出来的一套方法论,给预测者做人生吉凶的参考数据,在未来事业、财运、婚姻、家庭等问题时,能做出风险较低的决策。 八字排盘怎么看 八字排盘由年、月、日、时四柱组成,每柱包含一个天干和一个地支,共八个字。年柱代表出生的年份,月柱代表出生的月份,日柱代表出生的日期,时柱则代表出生的时辰。每个柱的干支组合都会对个人的命运产生影响。天干地支旁边标注的正财、偏财、偏印、正印、比肩、劫财、食神、伤官、正官、七杀等,称为十神。 2、八字排盘软件介绍 我们是腾讯云市场金牌合作伙伴,广州正规软件开发公司,开发的八字排盘系统数据最全面精准,我们八字排盘采用最精确的排盘程序,而且运用“真太阳时”,进行更精确的时间划分。大家都知道我们使用的北京时间,是统一规定的标准时间。而八字排盘需要相对于太阳方位的天文时间,即平太阳时。我们国家地大物博,北京时间19时,哈尔滨已经夜幕降临,而新疆却还是太阳高挂,这时哈尔滨的天文时间可能在20:00以后,而新疆的天文时间可能在16时以前。北京时间是东经120度经线的平太阳时,如果您出生地的经度与北京时间所处的经度差异较大,或者处于单数时间点的前后,比如6点差一刻,8点,10点15分等

23,217

社区成员

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

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