这是合法的吗?我正在尝试给定格式为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_wday
和tm_yday
字段,并根据其他字段为它们计算新值。 BSD扩展tm_gmtoff
和tm_zone
相同,除了它们是从本地时区计算得出的。
但是请注意,mktime()
使用本地时间,而不是UTC,因此,如果您输入的日期是UTC,则您的时区必须设置为UTC。