Linux编译器的存储分配

1.首先来看一下Linux上编译器划分存储布局的方式:

155033_8z0B_2010877.png


<内存地址的分配是由高到低的,内存地址的使用是由低到高的>


代码区:静态存储区域,由于生成目标代码的大小在编译时刻已经固定下来,因此编译器将可执行目标代码放在静态确定的区域,以只读方式访问;


静态区存储全局变量,这些变量的位置保持不变,并且在编译时刻可知,因此可以直接使用这些静态确定的地址;其中bss.段用来存放未初始化的全局变量,data.段用来存放已初始化的全局变量,还包括(static)静态变量(包括全局静态变量和局部静态变量)和常量数据(如:字符串常量)


堆  区  :存储生命周期比创造它的某次过程调用更长的数据,堆是虚拟内存的一个区域,它允许对象(new),或者其他数据(malloc、calloc、realloc)在创建时获得存储空间,并在数据变得无效时释放该存储空间,一般需要程序员手动释放free、delete等,另外堆向高地址方向增长;


栈  区  :用于存储局部变量,主要功能是存放活动记录的数据结构,这些活动记录在函数调用过程中生成,起着保护现场、恢复现场的职责,另外栈向低地址方向增长;








转载于:https://my.oschina.net/u/2010877/blog/394265

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值