C语言中变量的内存排布

之前对C语言的变量在内存中的排布有些混淆,故进行了以下几个方面的简要整理(所有的实例均是基于X86 PC Ubuntu上GCC编译的)。

  1. 变量定义时,不同的变量分配的内存地址的增长方向
    (1) 定义两个全局变量,在赋值编译后打印其在内存中分配的地址,发现先定义的变量被分配在内存中的低地址中
    C语言中变量的内存排布
    C语言中变量的内存排布
    (2) X86 PC Ubuntu的main函数中定义变量,使用gcc编译时查看系统对变量分配的内存地址(内存分配的增长方向是低地址到高地址)
    C语言中变量的内存排布
  2. 结构体实例化之后,结构体中成员分配的内存地址的增长方向
    (1) 定义全局结构体且初始化,gcc编译后查看结构体成员内存分配的增长方向(内存分配的增长方向是由低向高向上增长)
    C语言中变量的内存排布
    (2) 在main函数中对结构体且初始化,gcc编译后查看结构体成员内存分配的增长方向(内存分配的增长方向是由低向高向上增长)
    C语言中变量的内存排布
  3. 函数中定义变量时,使用的栈空间的内存的增长方向
    C语言中变量的内存排布
  4. arm在使用arm交叉编译工具链时,一般的变量的内存分配是向上增长方向的,但是对于栈上的内存分配时采用的满减栈的方式对栈上内存分配给变量使用的,栈的生长方向时向下生长方向的.

猜你喜欢

转载自blog.51cto.com/4265810/2462587