如何应用C语言变量的内存排布
一个典型的C程序存储分区包含以下几类:
创新互联建站主营城厢网站建设的网络公司,主营网站建设方案,成都app开发,城厢h5成都微信小程序搭建,城厢网站营销推广欢迎城厢等地区企业咨询
- Text段
- 已初始化数据段
- 未初始化数据段
- 栈
- 堆
之前对C语言的变量在内存中的排布有些混淆,故进行了以下几个方面的简要整理(所有的实例均是基于X86 PC Ubuntu上GCC编译的)。
- 变量定义时,不同的变量分配的内存地址的增长方向
(1) 定义两个全局变量,在赋值编译后打印其在内存中分配的地址,发现先定义的变量被分配在内存中的低地址中
(2) X86 PC Ubuntu的main函数中定义变量,使用gcc编译时查看系统对变量分配的内存地址(内存分配的增长方向是低地址到高地址)
- 结构体实例化之后,结构体中成员分配的内存地址的增长方向
(1) 定义全局结构体且初始化,gcc编译后查看结构体成员内存分配的增长方向(内存分配的增长方向是由低向高向上增长)
(2) 在main函数中对结构体且初始化,gcc编译后查看结构体成员内存分配的增长方向(内存分配的增长方向是由低向高向上增长)
- 函数中定义变量时,使用的栈空间的内存的增长方向
- arm在使用arm交叉编译工具链时,一般的变量的内存分配是向上增长方向的,但是对于栈上的内存分配时采用的满减栈的方式对栈上内存分配给变量使用的,栈的生长方向时向下生长方向的.
本文名称:如何应用C语言变量的内存排布
文章起源:http://myzitong.com/article/ipophj.html