我遇到了一个非常奇怪的问题。
代码如下:
::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
?答案 0 :(得分:11)
0xfeeefeee
是一个填充模式,Windows堆的调试版本(不是C运行时堆)用于未初始化的内存。 0xfeeefef2
是0xfeeefeee+4
。听起来你正在取消引用位于堆中分配的内存块中(或从中复制的)未初始化的指针。
在调试器中启动程序时,调试堆会自动启用,而不是使用调试器附加到已经运行的程序。
Mario Hewardt和Daniel Pravat的书 Advanced Windows Debugging 提供了关于Windows堆的一些不错的信息,事实证明,有关堆的章节是up on the web site as a sample chapter。
答案 1 :(得分:2)
当你这样做时
pImage=m_pStretchedDefaultThumbImage;
m_pStretchedDefaultThumbImage是否有可能未初始化?
答案 2 :(得分:0)
如果您粘贴的第三行上有pImage == NULL
会怎样?在这种情况下,rcShowImage
未分配值。