通过反汇编看编译器内存分配

本文以'hello world'程序为例,利用Ollydbg进行反汇编分析,探讨内存分配的细节。内容涵盖不同内存区域的用途、分配依据、内存类型以及程序的入口点。同时,文章讨论了堆、栈、全局静态区、常量区等在内存中的位置,以及如何理解内存分配图中的区段和页大小问题。
摘要由CSDN通过智能技术生成

   通过Ollydbg.exe看最普通的hello world这个程序,可以看到虚拟的4G分配

   程序:

   #include<stdio.h>

   int main(void)

{

printf("Hello world!/n");

return 0;

}

 

 

 

 

通过网上还没有找到这个分配图的详细具体信息。问题太多

1.从00000000~0000FFFF 这段内存是用来做什么的?

2.从1到46这个分配空间的依据是什么?为什么这样分配?

3.内存的类型是什么?priv,map,imag各自代表什么意思?

4.程序的载入程序的入口是哪里?

 

5.堆,栈,自由变量区,全局静态区,常量区分配在哪里?

6.区段及其包含的具体含义

7.755F0000的分配。

8。为什么主程序的所有主程序头,代码段数据段都是4K一页,如何更改?

内存分配图:

NO 地址 大小K 属主     区段 包含 类型 访问 初始访问 已映射为
1 00010000 64   10000 (自身)     Map  00041004 RW RW  
2 00020000 64   20000 (自身)     Map  00041004 RW RW  
3 0022D000 4   30000       Priv 00021104 RW  保护 RW  
4 0022E000 8   30000     堆栈 于 主线程 Priv 00021104 RW  保护 RW  
5 00230000 16   230000 (自身)     Map  00041002 R R  
6 00240000 4   240000 (自身)     Priv 00021004 RW RW  
7 00250000 412   250000 (自身)     Map  00041002 R R /Device/HarddiskVolume1/Windows/System32/locale.nls
8 002C0000 4   002C0000 (自身)    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值