1

我正在尝试将 bmp 文件读入字符缓冲区并使用进程间通信跨进程传输它。我使用以下代码完成了此操作:

     std::ifstream ImageFile;
     char* str=new char[strlen(pFilePath)+strlen(pFileName)+1];
     strcpy(str,pFilePath);
     strcat(str,pFileName);
     ImageFile.open(str, ios::binary); 
     if(ImageFile.is_open()){
         ImageFile.seekg(0,ios::end);
         m_uiImageSize = ImageFile.tellg();
         ImageFile.seekg(0,ios::beg);

         m_pcImageBuffer = new char[m_uiImageSize];
         ImageFile.read(m_pcImageBuffer,m_uiImageSize);
         ImageFile.close();
     }

     WebCore::FloatRect rect;
     BITMAP cBitmap;
     HBITMAP hBitmap;
     tagBITMAPFILEHEADER bfh = *(tagBITMAPFILEHEADER*)m_pcImageBuffer;
     tagBITMAPINFOHEADER bih = *(tagBITMAPINFOHEADER*)(m_pcImageBuffer+sizeof(tagBITMAPFILEHEADER));
     RGBQUAD             rgb = *(RGBQUAD*)(m_pcImageBuffer+sizeof(tagBITMAPFILEHEADER)+sizeof(tagBITMAPINFOHEADER));

     BITMAPINFO bi;
     bi.bmiColors[0] = rgb;
     bi.bmiHeader = bih;

     char* pPixels = (m_pcImageBuffer+bfh.bfOffBits);
     char* ppvBits;
     hBitmap = CreateDIBSection(NULL, &bi, DIB_RGB_COLORS, (void**) &ppvBits, NULL, 0);
     SetDIBits(NULL, hBitmap, 0, bih.biHeight, pPixels, &bi, DIB_RGB_COLORS);
     GetObject(hBitmap, sizeof(BITMAP), &cBitmap);

以前这对我来说非常有效。但是现在我的程序在 ImageFile.seekg(0,ios::end) 崩溃了,我不知道为什么。该文件可以正常打开,甚至 ifstream::good() 返回 true。以下是我的调用堆栈:

StorageTree.exe!std::use_facet >(const std::locale & _Loc) 第 586 行 C++
    msvcp110d.dll!std::basic_istream >::_Sentry_base::_Sentry_base(std::basic_istream > & _Istr) 第 103 行 C++
    msvcp110d.dll!std::basic_istream >::sentry::sentry(std::basic_istream > & _Istr, bool _Noskip) 第 123 行 C++
    msvcp110d.dll!std::basic_istream >::seekg(__int64 _Off, int _Way) 第 876 行 C++

请指导我正确的方向。

4

1 回答 1

0

找到了我的问题的解决方案。代码没有任何问题,我在应用程序中添加了更多代码并且没有初始化我的一些变量,从而影响了入口点和数据位置。

于 2013-10-25T08:18:50.023 回答