gcc代码反汇编查看内存分布[1]: gcc
# gcc -v
gcc version 4.4.5 (Ubuntu/Linaro 4.4.4-14ubuntu5)
重点:
代码中的内存分配, 地址从低到高: 代码段(RO, 保存函数代码) --> 只读数据段(RO, 保存常量) --> 数据段(RW, 已初始化并且初始值不为0的全局变量和静态变量) -->bss段(RW, 未初始化或者初始化为0的全局变量和静态变量).
程序运行起来之后, 堆区和栈区的变量地址是动态分配的.
- #include<stdio.h>
- #include<stdlib.h>
- int global_ni; // .bss
- int global_iz = ; // .bss
- int global_inz = ; // .data
- const int global_const0 = ;
- const int global_const1 = ;
- void function(void)
- {
- int local_fni;
- int local_finz = ;
- int local_fiz = ;
- static int static_fni;
- static int static_finz = ;
- static int static_fiz = ;
- int *p2 = (int*)malloc(sizeof(int));
- printf("子函数 局部变量 : \n");
- printf(" local_fni: %p \n", &local_fni);
- printf(" local_finz: %p \n", &local_finz);
- printf(" local_fiz: %p \n", &local_fiz);
- printf("子函数 静态变量 : \n");
- printf(" static_fni: %p \n", &static_fni);
- printf(" static_finz: %p \n", &static_finz);
- printf(" static_fiz: %p \n", &static_fiz);
- printf("子函数 指针变量 : \n");
- printf(" p2 : %p \n", p2);
- printf("子函数地址 : \n");
- printf(" function : %p \n", function);
- }
- int main(int argc, char **argv)
- {
- int local_mni;
- int local_minz = ;
- int local_miz = ;
- static int static_mni;
- static int static_minz = ;
- static int static_miz = ;
- int *p1 = (int*)malloc(sizeof(int));
- const int local_const0 = ;
- const int local_const1 = ;
- char* str_ptr = "char";
- printf("主函数 局部变量 : \n");
- printf(" local_mni : %p \n", &local_mni);
- printf(" local_minz : %p \n", &local_minz);
- printf(" local_miz : %p \n", &local_miz);
- printf("const 变量: \n");
- printf(" local_const0 : %p \n", &local_const0);
- printf(" local_const1 : %p \n", &local_const1);
- printf(" global_const0 : %p \n", &global_const0);
- printf(" global_const1 : %p \n", &global_const1);
- printf("主函数 malloc指针变量 : \n");
- printf(" p1 : %p \n", p1);
- printf("全局变量 : \n");
- printf(" global_ni : %p \n", &global_ni);
- printf(" global_inz : %p \n", &global_inz);
- printf(" global_iz : %p \n", &global_iz);
- printf("主函数 静态变量 : \n");
- printf(" static_mni: %p \n", &static_mni);
- printf(" static_minz: %p \n", &static_minz);
- printf(" static_miz: %p \n", &static_miz);
- printf("字符串常量 : \n");
- printf(" str_ptr : %p \n", str_ptr);
- printf("主函数地址 : \n");
- printf(" main : %p \n", main);
- printf("= = = = = = = = = = = = = = = \n");
- function();
- return ;
- }
- /*
- = = = = = = = = = = = = = = =
- 测试:
- gcc -o test main.c
- objdump -Dhs test > test.dis
- ./test
- 分析:
- Disassembly of section .text: 08048370
- {
- 子函数地址 :
- function : 0x8048424
- 主函数地址 :
- main : 0x804851d
- }
- Disassembly of section .rodata: 080487d8
- {
- const 变量: 全局
- global_const0 : 0x80487e0
- global_const1 : 0x80487e4
- 字符串常量 :
- str_ptr : 0x80488d0
- }
//.data中是初始化为非0的全局变量和静态变量- Disassembly of section .data: 0804a014
- {
- 子函数 静态变量 :
- static_finz: 0x804a024
- 全局变量 :
- global_inz : 0x804a01c
- 主函数 静态变量 :
- static_minz: 0x804a020
- }
- //.bss中是初始化为0以及没有初始化的全局变量和静态变量
- Disassembly of section .bss: 0804a028
- {
- 子函数 静态变量 :
- static_fni: 0x804a03c
- static_fiz: 0x804a040
- 全局变量 :
- global_iz : 0x804a030
- global_ni : 0x804a044
- 主函数 静态变量 :
- static_mni: 0x804a034
- static_miz: 0x804a038
- }
- 堆空间: //动态的
- {
- 主函数 malloc指针变量 :
- p1 : 0x967c008
- 子函数 malloc指针变量 :
- p2 : 0x967c018
- }
- 栈空间: //动态的
- {
- 子函数 局部变量 :
- local_fiz : 0xbfb79924
- local_finz: 0xbfb79928
- local_fni : 0xbfb7992c
- const 变量: 局部
- local_const1 : 0xbfe3cee8
- local_const0 : 0xbfe3ceec
- 主函数 局部变量 :
- local_miz : 0xbfb79964
- local_minz: 0xbfb79968
- local_mni : 0xbfb7996c
- }
- */
附反汇编文件test.dis节选
- test: file format elf32-i386
- Sections:
- Idx Name Size VMA LMA File off Algn
- .interp **
- CONTENTS, ALLOC, LOAD, READONLY, DATA
- .note.ABI-tag **
- CONTENTS, ALLOC, LOAD, READONLY, DATA
- .note.gnu.build-id **
- CONTENTS, ALLOC, LOAD, READONLY, DATA
- .gnu.hash 0804818c 0804818c 0000018c **
- CONTENTS, ALLOC, LOAD, READONLY, DATA
- .dynsym 080481ac 080481ac 000001ac **
- CONTENTS, ALLOC, LOAD, READONLY, DATA
- .dynstr 0804821c 0804821c 0000021c **
- CONTENTS, ALLOC, LOAD, READONLY, DATA
- .gnu.version 0000000e **
- CONTENTS, ALLOC, LOAD, READONLY, DATA
- .gnu.version_r **
- CONTENTS, ALLOC, LOAD, READONLY, DATA
- .rel.dyn 080482a4 080482a4 000002a4 **
- CONTENTS, ALLOC, LOAD, READONLY, DATA
- .rel.plt 080482ac 080482ac 000002ac **
- CONTENTS, ALLOC, LOAD, READONLY, DATA
- .init 080482d4 080482d4 000002d4 **
- CONTENTS, ALLOC, LOAD, READONLY, CODE
- .plt **
- CONTENTS, ALLOC, LOAD, READONLY, CODE
- .text 0000044c **
- CONTENTS, ALLOC, LOAD, READONLY, CODE
- .fini 0000001c 080487bc 080487bc 000007bc **
- CONTENTS, ALLOC, LOAD, READONLY, CODE
- .rodata 000002db 080487d8 080487d8 000007d8 **
- CONTENTS, ALLOC, LOAD, READONLY, DATA
- .eh_frame 08048ab4 08048ab4 00000ab4 **
- CONTENTS, ALLOC, LOAD, READONLY, DATA
- .ctors 08049f14 08049f14 00000f14 **
- CONTENTS, ALLOC, LOAD, DATA
- .dtors 08049f1c 08049f1c 00000f1c **
- CONTENTS, ALLOC, LOAD, DATA
- .jcr 08049f24 08049f24 00000f24 **
- CONTENTS, ALLOC, LOAD, DATA
- .dynamic 000000c8 08049f28 08049f28 00000f28 **
- CONTENTS, ALLOC, LOAD, DATA
- .got 08049ff0 08049ff0 00000ff0 **
- CONTENTS, ALLOC, LOAD, DATA
- .got.plt 08049ff4 08049ff4 00000ff4 **
- CONTENTS, ALLOC, LOAD, DATA
- .data 0804a014 0804a014 **
- CONTENTS, ALLOC, LOAD, DATA
- .bss 0804a028 0804a028 **
- ALLOC
- .comment 0000006c **
- CONTENTS, READONLY
gcc代码反汇编查看内存分布[1]: gcc的更多相关文章
- gcc代码反汇编查看内存分布[2]: arm-linux-gcc
arm-none-linux-gnueabi-gcc -v gcc version 4.4.1 (Sourcery G++ Lite 2010q1-202) 重点: 代码中的内存分配, 地址从低到高: ...
- 在VisualStudio调试器中使用内存窗口和查看内存分布
调试模式下内存窗口的使用 在调试期间,"内存"窗口显示应用使用的内存空间.调试器窗口(如"监视"."自动"."局部变量" ...
- 转载:C++类内存分布
本文转自:http://www.cnblogs.com/jerry19880126/p/3616999.html,原文写的非常好,从中学到了虚继承的概念,也学会了用VS查看内存分布. 说下C++内存分 ...
- C语言内存分布
C语言内存分布 典型的C语言程序内存表示分区共有5个部分: 正文段 Text segment 已初始化数据段(数据段)Initialized data segment 未初始化数据段(bss)Unin ...
- 1.预处理,生成预编译文件(.文件): Gcc –E hello.c –o hello.i 2.编译,生成汇编代码(.s文件): Gcc –S hello.i –o hello.s 3.汇编,生成目标文件(.o文件): Gcc –c hello.s –o hello.o 4.链接,生成可执行文件: linux笔记
1 动态查看日志 tail -f filename tail -1000f filename 2 解压当前目录内容为xxx.zip zip -r xxx.zip ./* 3 查看内存使用情况 fre ...
- C语言中内存分布及程序运行中(BSS段、数据段、代码段、堆栈)
BSS段:(bss segment)通常是指用来存放程序中未初始化的全局变量的一块内存区域.BSS是英文Block Started by Symbol的简称.BSS段属于静态内存分配. 数据段 : ...
- 浅析VS2010反汇编 VS 反汇编方法及常用汇编指令介绍 VS2015使用技巧 调试-反汇编 查看C语言代码对应的汇编代码
浅析VS2010反汇编 2015年07月25日 21:53:11 阅读数:4374 第一篇 1. 如何进行反汇编 在调试的环境下,我们可以很方便地通过反汇编窗口查看程序生成的反汇编信息.如下图所示. ...
- 使用汇编分析c代码的内存分布
arm平台下使用反汇编分析c内存分布: arm:使用arm-linux-objdump命令将编译完毕之后的elf文件,进行反汇编. 之后重定向到tmp.s文件里. 第一步变量例如以下c文件. vim ...
- 内存模型 Memory model 内存分布及程序运行中(BSS段、数据段、代码段、堆栈
C语言中内存分布及程序运行中(BSS段.数据段.代码段.堆栈) - 秦宝艳的个人页面 - 开源中国 https://my.oschina.net/pollybl1255/blog/140323 Mem ...
随机推荐
- 树莓派高级GPIO库,wiringpi2 for python使用笔记(三)GPIO操作
GPIO库的核心功能,当然就是操作GPIO了,GPIO就是"通用输入/输出"接口,比如点亮一个LED.继电器等,或者通过iic spi 1-wire等协议,读取.写入数据,这都是G ...
- composer api 参考
composer note 简介 composer 是php的依赖管理工具.可以声明项目所依赖的库,composer会帮我们安装上 composer 默认基于项目来管理和安装库(包),将依赖的库安装到 ...
- Pro/E 5.0安装图解教程(也适用于Creo Elements/Pro 5.0)
安装前必读:☆ 本教程适用于 32 位 proe 5.0 M010,M020,M030,M040,M050,M060 过程完全一样:☆ 本教程用于 64 位 proe 5.0 M010,M020,M0 ...
- 修改win7注册表发挥大容量内存优势
现在请打开注册表编辑器,找到[HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control \Session Manager\MomoryManagement ...
- HDU 5059 Help him
题解:先判断第一个是否负号.如果是把第一个符号拿掉之后判断后面的长度是否<=12,并且是否数字,然后转化成数字看看是否在[a,b],注意-0这个数据. 如果不是判断长度是否<=12,并且是 ...
- 1分钟搞定超慢SQL
前几天,一个用户的研发人员找到我了,说他们有个SQL语句非常慢,我说多慢?他们说:半个小时也没出结果.于是问他们要了SQL语句和执行计划,SQL语句就不能再这里贴出来了,下面是调整前的执行计划(略去某 ...
- CSS 布局总结——固定宽度布局
固定宽度布局 单列布局 watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvd2Fyd29sZjI0/font/5a6L5L2T/fontsize/400/fil ...
- Android 匿名共享内存C接口分析
在Android 匿名共享内存驱动源码分析中详细分析了匿名共享内存在Linux内核空间的实现,虽然内核空间实现了匿名共享内存,但仍然需要在用户空间为用户使用匿名共享内存提供访问接口.Android系统 ...
- python闭包以及装饰器
通俗的定义:如果在一个内部函数里,对在外部作用域(但不是在全局作用域)的变量进行引用,那么内部函数就被认为是闭包(closure).它只不过是个“内层”的函数,由一个名字(变量)来指代,而这个名字(变 ...
- zoj 2110
这道题困扰我的不是算法问题.而是细节问题.不优化一直搜到底 时间是690ms左右 没有优化的dfs #include<stdio.h> #include<string.h> # ...