chrono库碰到的那些坑

来源:互联网 发布:众泰e200和知豆 编辑:程序博客网 时间:2024/05/20 15:10

看过c++标准程序库的同学都知道在介绍chrono库时有这段代码:

#include <iostream>#include <chrono>#include <string>using namespace std;string asString(const chrono::system_clock::time_point& tp){    time_t t = chrono::system_clock::to_time_t(tp);    string ts = _ctime64(&t);    ts.resize(ts.size() - 1);    return ts;}int main(){    auto tp = chrono::system_clock::now();    cout << asString(tp) << endl;    auto tp2 = chrono::system_clock::time_point::min();    cout << asString(tp2);    system("pause");    return 0;}

运行到asString(tp2)就会出现异常了,异常点如下:

static size_t __CLRCALL_OR_CDECL length(_In_z_ const _Elem * const _First) _NOEXCEPT // strengthened        {   // find length of null-terminated string        return (_CSTD strlen(_First));        }

看这注释英文就知道我们试图输出一个空字符串(我用vs2017和qt creator调试都抛出异常)
由asString代码可知:
ts = ctime(&t);
ctime()函数返回的是char*,异常说我们抛出的异常是find length of null-terminated string,意思不就是这次返回的char*是个nullptr。
查了网络,问了人都无果,所以还是靠自己啊!!!
只能硬着头皮往后面翻了 c++ 标准程序库第三版是不是坑值得思考(毕竟我只是个小白)
此时出现第二段代码引起了我的思考:

#include <iostream>#include <chrono>#include <string>using namespace std;chrono::system_clock::time_point makeTimePoint(int year, int mon, int day, int hour, int min, int sec = 0){    struct tm t;    t.tm_year = year - 1900;    t.tm_mon = mon - 1;    t.tm_mday = day;    t.tm_hour = hour;    t.tm_min = min;    t.tm_isdst = -1;    t.tm_sec = sec;    time_t tt = mktime(&t);    /*if (tt == -1)    throw "no valid system time";*/    return chrono::system_clock::from_time_t(tt);}

一开始我写错了,把1990写成了1990而且直接输出tt,最后得到tt为-1,这不正好不合理吗!!(用书上的数据)
后来我脑子聪明(知道反其道其行)

#include <iostream>#include <chrono>#include <string>using namespace std;chrono::system_clock::time_point makeTimePoint(int year, int mon, int day, int hour, int min, int sec = 0){    struct tm t;    t.tm_year = year - 1900;    t.tm_mon = mon - 1;    t.tm_mday = day;    t.tm_hour = hour;    t.tm_min = min;    t.tm_isdst = -1;    t.tm_sec = sec;    time_t tt = mktime(&t);    /*if (tt == -1)    throw "no valid system time";*/    return chrono::system_clock::from_time_t(tt);}string asString(const chrono::system_clock::time_point &tp){    time_t t = chrono::system_clock::to_time_t(tp);    string ts = ctime(&t);    ts.resize(ts.size() - 1);    return ts;}int main(){    auto tp = makeTimePoint(2010, 01, 01, 00, 00);    cout << asString(tp);    time_t t = chrono::system_clock::to_time_t(chrono::system_clock::time_point::min());    /*tm *tt = localtime(&t);    tp = makeTimePoint(tt->tm_year, tt->tm_mon, tt->tm_mday, tt->tm_hour, tt->tm_min);*/    cout << asString(tp);    system("pause");    return 0;}

注释的tt内容是运行不了的,因为得到是nullptr,这就说明chrono::system_clock::time_point::min()是得不到strcut tm也就更得不到ctime()返回的char*非nullptr了,而且查知chrono::system_clock::time_point::min()是负数,怎么可能用来表示时间
所以总结出:对于不合理的时间就别想着这样输出了,也没存在的意义
(也不知道写书的大佬是怎么搞出来的,望各位大佬赐教),不过我之前用__time32_t输出过min,max还是不行,,可能还有坑,我还是不深入了吧

原创粉丝点击