标题:使用OllyDbg 反汇编无法查看堆地址?
只看楼主
vfdff
Rank: 6Rank: 6
等 级:侠之大者
威 望:8
帖 子:2172
专家分:425
注 册:2005-7-15
结帖率:79.17%
 问题点数:0 回复次数:0 
使用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 反汇编软件的整个 内存映射 的地址范围中就没有这部分的范围
谁知道这个堆地址是在哪里的 ?

缺失堆地址.JPG (93.81 KB)
搜索更多相关主题的帖子: 堆地址 缺失 变量地址分布 
2008-11-01 12:53



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-241844-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.296187 second(s), 9 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved