C++ 为什么在打开的文件上使用QTextStream时会发生崩溃*
我在windows上,Qt4.7。我的部分代码从一个文件中获取一个文件*,该文件已打开供系统的另一部分(legacy,C)读取。我打开一个QTextStream,如下所示:C++ 为什么在打开的文件上使用QTextStream时会发生崩溃*,c++,qt,qtextstream,C++,Qt,Qtextstream,我在windows上,Qt4.7。我的部分代码从一个文件中获取一个文件*,该文件已打开供系统的另一部分(legacy,C)读取。我打开一个QTextStream,如下所示: // file currently opened (readonly), and partially read FILE *infile = function_to_get_file_pointer(); QTextStream is(infile, QIODevice::ReadOnly); 第二行在版本模式下构建时崩
// file currently opened (readonly), and partially read
FILE *infile = function_to_get_file_pointer();
QTextStream is(infile, QIODevice::ReadOnly);
第二行在版本模式下构建时崩溃,但在调试时可以正常运行。我可以逐步查看调试版本,并查看QTextStream在内部打开的QFile。
崩溃时,我在发布模式下从windows调用堆栈中获得的最多信息如下:
ntdll.dll!77450226()
[Frames below may be incorrect and/or missing, no symbols loaded for ntdll.dll]
ntdll.dll!77450142()
msvcr80.dll!_lock_file(_iobuf * pf=0x71962148) Line 241 + 0xa bytes C
msvcr80.dll!_ftelli64(_iobuf * stream=0x71962148) Line 51 + 0x8 bytes C
QtCore4.dll!6708b87d()
QtCore4.dll!67099294()
QtCore4.dll!6713d491()
这可能是在转移视线,但在试图锁定文件时似乎出了问题。在此之前,我已经为代码启用了调试输出,因此我知道是QTextStream创建导致了问题。
我欢迎任何建议
在进一步挖掘之后,我发现该文件虽然是ASCII码,但最初是用“rb”打开的,目的是为了阻止win32 CRT将行结尾从\r\n转换为\r\n。
我认为这会让Qt感到困惑,所以修改了fopen,只使用“r”。然后,下面链接到的注释显示文件*应以二进制模式打开,例如“rb”,因此这不是问题
尝试下面的tezrigs建议,freopen on the FILE*给出以下内容:
msvcr100.dll!_crt_debugger_hook(int _Reserved=8633404) Line 65 C
msvcr100.dll!_call_reportfault(int nDbgHookCode=2, unsigned long dwExceptionCode=3221226519, unsigned long dwExceptionFlags=1) Line 167 + 0x6 bytes C++
msvcr100.dll!_invoke_watson(const wchar_t * pszExpression=0x00000000, const wchar_t * pszFunction=0x00000000, const wchar_t * pszFile=0x00000000, unsigned int nLine=0, unsigned int pReserved=8633376) Line 155 + 0xf bytes C++
msvcr100.dll!_invalid_parameter(const wchar_t * pszExpression=0x00000000, const wchar_t * pszFunction=0x00000000, const wchar_t * pszFile=0x00000000, unsigned int nLine=0, unsigned int pReserved=0) Line 110 + 0x14 bytes C++
msvcr100.dll!_invalid_parameter_noinfo() Line 121 + 0xc bytes C++
msvcr100.dll!_freopen_helper(_iobuf * * pfile=0x0083bc3c, const char * filename=0x00000000, const char * mode=0x013ee350, _iobuf * str=0x71962148, int shflag=64) Line 31 + 0x1f bytes C
msvcr100.dll!freopen(const char * filename=0x00000000, const char * mode=0x013ee350, _iobuf * str=0x71962148) Line 111 C
传递给_call_report_fault的异常代码是0x0000417-致命错误:未知软件异常,这没有多大帮助
确定:更多细节,以及一些自包含的可复制代码(myfile.txt的长度必须超过1000个字符):
#包括
#包括“qtextstream.h”
#包括
int main(int argc,char*argv[])
{
//qcorea应用程序(argc、argv);
std::cin.get();
FILE*myfile=fopen(“myfile.txt”、“rb”);
INTC;
对于(int i=0;i<1000;i++)
c=getc(myfile);
fflush(myfile);
long pos=ftell(myfile);
QTextStream是(myfile,QIODevice::ReadOnly);
而(!is.atEnd())
{
QString in_line=is.readLine();
std::cout这一切都归功于@KarstenKoop-请在此处随意发布您的答案。问题是由于Qt dll使用的是msvcr80.dll,而应用程序的其余部分是使用visual studio 2010编译的,因此使用的是msvcr100.dll
这就很好地解释了将VisualStudio版本混合使用的危险性`FILE*infle=function_to_get_FILE_pointer();infle=freopen(NULL,“rb”,infle);QTextStream是(infle,QIODevice::ReadOnly)`function_to_get_FILE_pointer()的内部
可能会澄清这一点。你能验证它是否返回了有效的文件指针吗?尝试自己调用ftell
,它会崩溃吗?@mike我看到这一点时得到了提示。有一个特殊的windows用户部分。你能在创建QTextStream之前尝试刷新吗?我同时看到msvcr80.dll和msvcr100.dll,这可能是一个错误吗这两者之间的版本冲突?
#include <QtCore/QCoreApplication>
#include "qtextstream.h"
#include <iostream>
int main(int argc, char *argv[])
{
// QCoreApplication a(argc, argv);
std::cin.get();
FILE *myfile = fopen("myfile.txt", "rb");
int c;
for(int i=0; i < 1000; i++)
c = getc(myfile);
fflush(myfile);
long pos = ftell(myfile);
QTextStream is(myfile, QIODevice::ReadOnly);
while(!is.atEnd())
{
QString in_line = is.readLine();
std::cout << in_line.toStdString();
}
fseek(myfile, pos, SEEK_SET);
fclose(myfile);
return 0;
}