arm-none-linux-gnueabi-gcc -v

  gcc version 4.4.1 (Sourcery G++ Lite 2010q1-202)

重点:

  代码中的内存分配, 地址从低到高: 代码段(RO, 保存函数代码) --> 只读数据段(RO, 保存常量) --> 数据段(RW, 已初始化并且初始值不为0的全局变量和静态变量) -->bss段(RW,  未初始化或者初始化为0的全局变量和静态变量).

  程序运行起来之后, 堆区和栈区的变量地址是动态分配的.

可以看出arm-none-linux-gnueabi-gcc编译和gcc编译结果是类似的.

#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 ;
} /*
= = = = = = = = = = = = = = =
测试:
arm-none-linux-gnueabi-gcc -o test main.c
arm-none-linux-gnueabi-objdump -Dhs test > test.dis 分析:
Disassembly of section .text: 000083e0
{
子函数地址 :
function :
主函数地址 :
main : } Disassembly of section .rodata: 000088c0
{
const 变量: 全局
global_const0
global_const1
字符串常量 : str_ptr
}
//.data中是初始化为非0的全局变量和静态变量
Disassembly of section .data: 00010d5c
{
global_inz
static_minz
static_finz
} //.bss中是初始化为0以及没有初始化的全局变量和静态变量
Disassembly of section .bss: 00010d70
{
global_iz
static_mni
static_miz
static_fni
static_fiz
global_ni } 堆空间: //动态的
{
主函数 malloc指针变量 :
p1 : 子函数 malloc指针变量 :
p2 :
} 栈空间: //动态的
{
子函数 局部变量 :
local_fiz :
local_finz:
local_fni : const 变量: 局部
local_const1 :
local_const0 : 主函数 局部变量 :
local_miz :
local_minz:
local_mni :
}
*/

反汇编文件test.dis节选

test:     file format elf32-littlearm

Sections:
Idx Name Size VMA LMA File off Algn
.interp **
CONTENTS, ALLOC, LOAD, READONLY, DATA
.note.ABI-tag **
CONTENTS, ALLOC, LOAD, READONLY, DATA, LINK_ONCE_SAME_CONTENTS
.hash 0000003c **
CONTENTS, ALLOC, LOAD, READONLY, DATA
.dynsym 000000a0 000081a4 000081a4 000001a4 **
CONTENTS, ALLOC, LOAD, READONLY, DATA
.dynstr 000000a7 **
CONTENTS, ALLOC, LOAD, READONLY, DATA
.gnu.version 000082ec 000082ec 000002ec **
CONTENTS, ALLOC, LOAD, READONLY, DATA
.gnu.version_r **
CONTENTS, ALLOC, LOAD, READONLY, DATA
.rel.dyn **
CONTENTS, ALLOC, LOAD, READONLY, DATA
.rel.plt **
CONTENTS, ALLOC, LOAD, READONLY, DATA
.init 0000000c **
CONTENTS, ALLOC, LOAD, READONLY, CODE
.plt 0000005c **
CONTENTS, ALLOC, LOAD, READONLY, CODE
.text 000004d8 000083e0 000083e0 000003e0 **
CONTENTS, ALLOC, LOAD, READONLY, CODE
.fini 000088b8 000088b8 000008b8 **
CONTENTS, ALLOC, LOAD, READONLY, CODE
.rodata 000088c0 000088c0 000008c0 **
CONTENTS, ALLOC, LOAD, READONLY, DATA
.ARM.extab 00008bd4 00008bd4 00000bd4 **
CONTENTS, ALLOC, LOAD, READONLY, DATA
.ARM.exidx 00008bf8 00008bf8 00000bf8 **
CONTENTS, ALLOC, LOAD, READONLY, DATA
.init_array 00010c38 00010c38 00000c38 **
CONTENTS, ALLOC, LOAD, DATA
.fini_array 00010c3c 00010c3c 00000c3c **
CONTENTS, ALLOC, LOAD, DATA
.jcr 00010c40 00010c40 00000c40 **
CONTENTS, ALLOC, LOAD, DATA
.dynamic 000000f0 00010c44 00010c44 00000c44 **
CONTENTS, ALLOC, LOAD, DATA
.got 00010d34 00010d34 00000d34 **
CONTENTS, ALLOC, LOAD, DATA
.data 00010d5c 00010d5c 00000d5c **
CONTENTS, ALLOC, LOAD, DATA
.bss 0000001c 00010d70 00010d70 00000d70 **
ALLOC
.ARM.attributes 0000002b 00000d70 **
CONTENTS, READONLY
.comment 0000002b 00000d9b **
CONTENTS, READONLY
.debug_frame 00000dc8 **
CONTENTS, READONLY, DEBUGGING

gcc代码反汇编查看内存分布[2]: arm-linux-gcc的更多相关文章

  1. gcc代码反汇编查看内存分布[1]: gcc

    # gcc -vgcc version 4.4.5 (Ubuntu/Linaro 4.4.4-14ubuntu5) 重点: 代码中的内存分配, 地址从低到高: 代码段(RO, 保存函数代码) --&g ...

  2. 在VisualStudio调试器中使用内存窗口和查看内存分布

    调试模式下内存窗口的使用 在调试期间,"内存"窗口显示应用使用的内存空间.调试器窗口(如"监视"."自动"."局部变量" ...

  3. Ubuntu12.4 64位 安装 arm linux gcc 4.3.2

    一.下载arm linux gcc 4.3.2 http://pan.baidu.com/share/link?shareid=1575352696&uk=2754759285&fid ...

  4. 代码内存泄露检测工具(linux gcc + valrind)

    参考博客: https://www.cnblogs.com/wangkangluo1/archive/2011/07/20/2111248.html linux命令如下:valgrind --tool ...

  5. 转载:C++类内存分布

    本文转自:http://www.cnblogs.com/jerry19880126/p/3616999.html,原文写的非常好,从中学到了虚继承的概念,也学会了用VS查看内存分布. 说下C++内存分 ...

  6. C语言内存分布

    C语言内存分布 典型的C语言程序内存表示分区共有5个部分: 正文段 Text segment 已初始化数据段(数据段)Initialized data segment 未初始化数据段(bss)Unin ...

  7. 使用汇编分析c代码的内存分布

    arm平台下使用反汇编分析c内存分布: arm:使用arm-linux-objdump命令将编译完毕之后的elf文件,进行反汇编. 之后重定向到tmp.s文件里. 第一步变量例如以下c文件. vim ...

  8. C语言中内存分布及程序运行中(BSS段、数据段、代码段、堆栈)

      BSS段:(bss segment)通常是指用来存放程序中未初始化的全局变量的一块内存区域.BSS是英文Block Started by Symbol的简称.BSS段属于静态内存分配. 数据段 : ...

  9. 浅析VS2010反汇编 VS 反汇编方法及常用汇编指令介绍 VS2015使用技巧 调试-反汇编 查看C语言代码对应的汇编代码

    浅析VS2010反汇编 2015年07月25日 21:53:11 阅读数:4374 第一篇 1. 如何进行反汇编 在调试的环境下,我们可以很方便地通过反汇编窗口查看程序生成的反汇编信息.如下图所示. ...

随机推荐

  1. TCP的阻塞和重传

    TCP的阻塞和重传 TCP的阻塞和重传机制 网络拥堵 现在网络上大部分的网络请求都是以TCP的方式进行传输的了.网络链路是固定的,各种链路情况也是不一样的.网络拥堵一直是TCP协议设计和使用的时候尽力 ...

  2. 《Java4Android视频教程》学习笔记(三)

    一:抽象类 接口 1.使用abstract修饰抽象类 抽象函数 2.一个类中有一个或者多个抽象函数,必须定义为抽象类 3.抽象类可以不含有抽象函数 4.抽象类不可以生成对象 tip:如果一个代码在语意 ...

  3. Orz 终于有了自己的博客地址

    新博客地址:http://www.wnjxyk.cn/

  4. java的控制流程

    1.顺序结构顺序结构就是指按语句执行的先后顺序,或者说语句出现的先后顺序逐条执行程序语句.语句块,完全是按照程序平台的执行约定进行的,比如第一个 HelloWorld程序:public class H ...

  5. Android面试题06

    51. 一条最长的短信息约占多少byte? 中文70(包括标点),英文160,160个字节 这个说法不准确, 要跟手机制式运营商等信息有关. 做实验,看源码 ArrayList<String&g ...

  6. 设计模式入门之桥接模式Bridge

    Abstraction:抽象部分的父类,定义须要实现的接口.维护对实现部分的引用,从而把实现桥接到Implementor中去 Implementor:实现部分的接口 RefinedAbstractio ...

  7. css3选择器的比较(二) -- 包含字符串

    二.  包含“字符串” 两种用法的区别是: a. “~=”,需要用空格分割, b. "*=",不需要任何分隔符 1. 资料 a) b)  2. html代码 <div tit ...

  8. objective-C学习笔记(十)协议

    协议 Protocol 协议是类的合同约定,只描述外部接口,不提供具体实现.所以,协议其实可以写在类的.h文件中,不去实现就可以了. 协议可以包含以下成员: 属性 (编译器不会和普通interface ...

  9. 浅谈Struts2(二)

    一.struts2的跳转 1.action跳转JSP a.默认为forward <action name="action1" class="com.liquidxu ...

  10. 各种输入速度比较(cin,scanf,getchar,pascal的read)

    每个程序都是纯读入与1个输出.输入数据分别有1e2,1e3,1e4,1e5,1e6,1e7个数. C++使用getchar()读入是最快的.流输入是非常非常慢! 比赛还是用gechar比较好...