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); 第二行在版本模式下构建时崩

我在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);
第二行在版本模式下构建时崩溃,但在调试时可以正常运行。我可以逐步查看调试版本,并查看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;
}