c++将strftime转换为string

C++, strftime to string

本文关键字:string 转换 strftime c++      更新时间:2023-10-16

我做这个函数是为了以字符串的形式获得所需的时间信息。

string gettimeinfo()
{
    tm * timeinfo;
    time_t rawtime;
    char timebuff[120] = {0};
    time(&rawtime);
    timeinfo = localtime(&rawtime);
    strftime(timebuff, 120, "%d.%m.%Y. %H:%M:%S %x %W %I:%M %p %a %b %A %B %Zn", timeinfo);
    return string(timebuff);
}

编译没有错误,并按预期工作。
但是当调试代码时:blocks/GCC程序停止在返回语句和调试警告出现:

In std::basic_string<char, std::char_traits<char>, std::allocator<char> >::basic_string(char const*, std::allocator<char> const&) () ()

发生了什么,如何摆脱它?

编辑:整个错误是:

In std::basic_string<char, std::char_traits<char>, std::allocator<char> >::basic_string(char const*, unsigned int, std::allocator<char> const&) () ()
#1  0x004013fe in gettimeinfo () at C:programi[connectcppgeneral.cpp:36
C:programi[connectcppgeneral.cpp:36:785:beg:0x4013fe
At C:programi[connectcppgeneral.cpp:36
In char* std::string::_S_construct<char const*>(char const*, char const*, std::allocator<char> const&, std::forward_iterator_tag) () ()
In std::string::_Rep::_S_create(unsigned int, unsigned int, std::allocator<char> const&) () ()
In operator new(unsigned int) () ()

首先,您应该至少检查strftime的返回值。如果它返回0,你的缓冲区是无效的,你不应该尝试从它构造一个字符串。

其次,new中的错误通常意味着在执行此操作之前堆已损坏。如果你插入
std::string tmp("heap test");
例如,在返回语句之前的

,并且以同样的方式失败,那么您肯定有一些先前的损坏(遗憾的是,反过来并不成立,因为这些事情通常不是确定的)。使用valgrind或其他堆检查器是更好的选择。