0

我遇到了一个非常奇怪的问题。

代码如下:

::boost::shared_ptr<CQImageFileInfo> pInfo=CQUserViewDataManager::GetInstance()->GetImageFileInfo(nIndex); 
Image* pImage=pInfo->m_pThumbnail;
if(pImage==NULL)
    pImage=m_pStretchedDefaultThumbImage;
else
{
    //
    int sourceWidth  = pInfo->GetWidth();
    int sourceHeight = pInfo->GetHeight();

    int destX = 0,
        destY = 0; 

    float nPercent  = 0;
    float nPercentW = ((float)GetThumbImageWidth()/(float)sourceWidth);;
    float nPercentH = ((float)GetThumbImageHeight()/(float)sourceHeight);

    if(nPercentH < nPercentW)
    {
        nPercent = nPercentH;
        destX    = (int)((GetThumbImageWidth() - (sourceWidth * nPercent))/2);
    }
    else
    {
        nPercent = nPercentW;
        destY    = (int)((GetThumbImageHeight() - (sourceHeight * nPercent))/2);
    }

    int destWidth  = (int)(sourceWidth * nPercent);
    int destHeight = (int)(sourceHeight * nPercent);
    rcShowImage=CRect(rc.left+destX, rc.top+destY,rc.left+destX+destWidth,rc.top+destY+destHeight);
}
ASSERT(pImage != NULL); // passed assertion...
graphics.DrawImage(pImage,rcShowImage.left,rcShowImage.top,
rcShowImage.Width(),rcShowImage.Height()); // problem happened here.

我收到以下异常:

First-chance exception at 0x004095b0 in ec.exe: 0xC0000005: Access violation reading location 0xfeeefef2.
Unhandled exception at 0x004095b0 in ec.exe: 0xC0000005: Access violation reading location 0xfeeefef2.

我已经检查了pImage,我确定什么时候graphics.DrawImage被调用,它不是NULL

  • 为什么会出现这样的问题?
  • 是什么0xfeeefef2
4

3 回答 3

11

0xfeeefeee是 Windows 堆的调试版本(不是 C 运行时堆)用于未初始化内存的填充模式。0xfeeefef20xfeeefeee+4。听起来您正在取消引用位于(或复制自)从堆分配的内存块中的未初始化指针。

当您在调试器中启动程序时,调试堆会自动启用,而不是使用调试器附加到已经运行的程序。

Mario Hewardt 和 Daniel Pravat所著的Advanced Windows Debugging一书提供了一些关于 Windows 堆的不错信息,事实证明,关于堆的章节作为示例章节已在网站上发布

于 2008-11-06T03:47:14.087 回答
2

当你这样做

pImage=m_pStretchedDefaultThumbImage;

m_pStretchedDefaultThumbImage 是否有可能未初始化?

于 2008-11-06T03:32:58.483 回答
0

如果pImage == NULL在第三行粘贴会发生什么?在这种情况下,rcShowImage不分配值。

于 2008-11-06T03:28:55.230 回答