c – 从YYYYMMDDHHMMSS字符串获取time_t的最快方法
作者:互联网
这是合法的吗?我试图尽可能快地得到time_t给定一个格式为YYYYMMDDHHMMSS的字符串.
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.
标签:c-3,time-t,mktime,linux,date 来源: https://codeday.me/bug/20190730/1578107.html