AccessViolation调试有趣

AccessViolation debugging fun

本文关键字:调试 AccessViolation      更新时间:2023-10-16

我有一个c++代码块,看起来像这样

LPBYTE FindBits(const BITMAPINFOHEADER *pbi)
{
    return (LPBYTE)pbi + pbi->biSize + FindColorTableBytes(pbi);
}

获取一个指向实际dib(位图)数据的指针。

现在,我有一个多线程c#应用程序,它从所有不同的文件(理论上)加载位图,从来没有一次相同的一个。它使用我的c++ dll来读取和解码文档中的位图。

问题是我试图使这个库在多个线程上安全,但我在上面函数的行中得到AccessViolationError。在尝试调试此问题时,当错误发生时调试器会中断,我查看pbi的成员。它们看起来像这样:

{biSize=??? biWidth=??? biHeight=??? ...}

pbi是位图内存,使用GlobalLock(handleToDib)锁定,甚至要获得上述函数以获得访问冲突,GlobalLock必须返回一个非空指针。

当我在内存窗口中查看GlobalLock返回的内存位置时,它看起来是这样的:

? ??? ?? ?? ?? ??

如果调试器给我一个神奇的数字,我可以理解如果内存不好…但这让我很困惑……显然还有调试器。有人知道调试器为什么显示这个吗?

MSVS调试器已经足够好了。
使用内存窗口查看对象的原始结构,使用反汇编窗口精确执行指令。

当然OllyDbg可以更方便地完成这样的任务(对于知道如何使用它的人),但它不像MSVS的调试器那么容易。