使用OllyDbg 反汇编无法查看堆地址?
使用代码 (部分代码)int main()
{
g_iShared = 0x98;
iGlobal = 0xed;
int iLocal = 0x33;
int *iPointer=new int(0x55);
printf("0x%x,0x%p\n",g_iShared,&g_iShared);
printf("0x%x,0x%p\n",iGlobal,&iGlobal);
printf("0x%x,0x%p\n",iLocal,&iLocal);
printf("0x%x,0x%p,0x%p\n",*iPointer,\
iPointer,&iPointer);
delete iPointer;
return 0;
}
做了个简单的试验,发现OllyDbg 反汇编无法查看堆地址。
由程序显示结果 指针 iPointer 申请的内存空间应该在堆中,于是上述显示中的地址 0x00380F60 应该就是堆地址中的一个储存单元
分析了堆栈的地址空间: 0012e000 ~ 0012e000+2000 = 0012e000 ~ 00130000 < 0x00380F60,显然它不属于这个范围
然后分析最接近的地址空间:00330000 ~ 00330000 +41000 =00371000 < 0x00380F60 ,它也不在这个地址范围内。
而接下来的地址0x400000 > 0x00380F60
于是 OllyDbg 反汇编软件的整个 内存映射 的地址范围中就没有这部分的范围
谁知道这个堆地址是在哪里的 ?