C++ 将字符串转换为 time_t 变量

Ada*_*m F 2 c++ string lua datetime

我正在开发一个 C++ 函数,该函数应该确定两个时间点之间是否发生了指定的事件。事件名称、开始日期时间和结束日期时间都是从 Lua 作为字符串传入的。因此,我需要将日期时间字符串解析为 time_t 变量。根据我在 StackOverflow 和其他论坛上看到的内容,此代码应该可以工作:

time_t tStart;
int yy, month, dd, hh, mm, ss;
struct tm whenStart = {0};
const char *zStart = startTime.c_str();

sscanf(zStart, "%d/%d/%d %d:%d:%d", &yy, &month, &dd, &hh, &mm, &ss);
whenStart.tm_year = yy - 1900;
whenStart.tm_mon = month - 1;
whenStart.tm_mday = dd;
whenStart.tm_hour = hh;
whenStart.tm_min = mm;
whenStart.tm_sec = ss;
whenStart.tm_isdst = -1;

tStart = mktime(&whenStart);
Run Code Online (Sandbox Code Playgroud)

但是,此处 tStart 似乎被分配了值 -1。如果我使用 strftime 从 whenStart 重建字符串,则该 tm 结构似乎已完全正确。我认为 mktime() 不喜欢这种结构。这段代码有什么问题?

另外,在您回答之前,请知道我已经尝试使用 strptime() 调用。由于我不清楚的原因,该函数被拒绝,并出现“未定义的对‘strptime’的引用”错误。发现的有关如何解决此问题的各种 描述只会 破坏我正在使用的代码库的其余部分,因此我宁愿避免弄乱 _XOPEN_SOURCE 或类似的重新定义。

感谢您的帮助!

Ste*_*mer 5

您发布的代码是正确的。

这让我相信您的输入字符串 ( startTime) 不是您期望的格式,因此sscanf无法解析出这些值。

例子:

#include <iostream>

int main()
{
    std::string startTime = "2016/05/18 13:10:00";

    time_t tStart;
    int yy, month, dd, hh, mm, ss;
    struct tm whenStart;
    const char *zStart = startTime.c_str();

    sscanf(zStart, "%d/%d/%d %d:%d:%d", &yy, &month, &dd, &hh, &mm, &ss);
    whenStart.tm_year = yy - 1900;
    whenStart.tm_mon = month - 1;
    whenStart.tm_mday = dd;
    whenStart.tm_hour = hh;
    whenStart.tm_min = mm;
    whenStart.tm_sec = ss;
    whenStart.tm_isdst = -1;

    tStart = mktime(&whenStart);

    std::cout << tStart << std::endl;
}
Run Code Online (Sandbox Code Playgroud)

输出:

1463595000

您是否理智地检查过您的输入?

请注意,您可以检查 的返回值sscanf来验证它是否按您的预期工作。

返回值
成功分配的接收参数的数量,如果在分配第一个接收参数之前发生读取失败,则返回 EOF。

如果返回值不是6,则输入字符串不正确。

int num_args = sscanf(zStart, "%d/%d/%d %d:%d:%d", &yy, &month, &dd, &hh, &mm, &ss);
if (num_args != 6)
{
    std::cout << "error in format string " << startTime << '\n';
    return 1;
}
Run Code Online (Sandbox Code Playgroud)

根据经验,您不应该假设您的输入是正确的。因此,防御性编程是一个值得养成的好习惯。