看过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还是不行,,可能还有坑,我还是不深入了吧