具体原因可参考这篇文章https://cloud.tencent.com/developer/article/1434344
大概意思就是采用静态链接编译(/MT)方式,调用的库返回的对象的内存是在所调用的dll处开辟的,本地程序用完该对象释放资源就是抛出这个异常。
由于我项目调用的库必须使用/MT方式,所以也出现了这个问题。
看看我出现的情况:
QString pfxPassStr = jsonObj.value("pfxpass").toString();
std::string passStr = pfxPassStr.toStdString();
const char *ch = passStr.c_str();
#if 1
QByteArray pfxPassData = QByteArray::fromBase64(ch);
#else
QByteArray pfxPassData = QByteArray::fromBase64(pfxPassStr.toLocal8Bit());
#endif
我的目的是把pfxPassStr进行base64解码,一开始我使用的是转成std::string→char *再调用解码的函数,使用这种方式后,当函数执行结束,passStr的资源就会被释放,这时候就会抛出Expression: __acrt_first_block == header的异常。采用下面的方式就不会出现了。猜测toStdString函数会调用到标准c++ string的库,内存在是另外的dll开辟的,所以会出现这个问题,而且我没有包含string的头文件也能使用string,可能QString里面就包含了string的头文件,当然这只是我的猜测。
当使用/MT方式编译的话,这方面得注意了