这是合法的吗?我正在尝试给定格式为YYYYMMDDHHMMSS的字符串,尽快达到time_t。

static time_t ConvertToSecSince1970(char *szYYYYMMDDHHMMSS)
{
struct tm    Tm;

    memset(&Tm, 0, sizeof(Tm));
    Tm.tm_year = makeInt(szYYYYMMDDHHMMSS +  0, 4) - 1900;
    Tm.tm_mon  = makeInt(szYYYYMMDDHHMMSS +  4, 2) - 1;
    Tm.tm_mday = makeInt(szYYYYMMDDHHMMSS +  6, 2);
    Tm.tm_hour = makeInt(szYYYYMMDDHHMMSS +  8, 2);
    Tm.tm_min  = makeInt(szYYYYMMDDHHMMSS + 10, 2);
    Tm.tm_sec  = makeInt(szYYYYMMDDHHMMSS + 12, 2);
    return mktime(&Tm);
}

如果我使用以下方法创建TM,似乎会产生相同的答案:
strptime(szYYYYMMDDHHMMSS, "%Y%m%d%H%M%S", &Tm);

我担心tm_yday,tm_wday,tm_isdst,tm_gmtoff,tm_zone很重要。我的日期是UTC,所以我认为gmtoff = 0和tm_zone = 0可能有效。

顺便说一下,这是makeInt:
inline int makeInt(const char *p, int size)
{
    const char *endp;
    int intval = 0;

    endp = p + size;
    while (p < endp)
    {
        intval = intval * 10 + *p - '0';
        p++;
    }
    return intval;
}

最佳答案

mktime()忽略tm_wdaytm_yday字段,并根据其他字段为它们计算新值。 BSD扩展tm_gmtofftm_zone相同,除了它们是从本地时区计算得出的。

但是请注意,mktime()使用本地时间,而不是UTC,因此,如果您输入的日期是UTC,则您的时区必须设置为UTC。

08-17 19:12