下载后可任意编辑1 Linux x86_64 与 i386 区别之 —— 内存寻址 收藏 2 1 引子毫无疑问,不管是 32 位,还是 64 位处理器,所有进程(执行的程序)都必须占用一定数量的内存,它或是用来存放从磁盘载入的程序代码,或是存放取自用户输入的数据等等
不过进程对这些内存的管理方式因内存用途不一而不尽相同,有些内存是事先静态分配和统一回收的,而有些却是按需要动态分配和回收的
对任何一个普通进程来讲,它都会涉及到 5 种不同的数据段
稍有编程知识的朋友都该能想到这几个数据段种包含有“程序代码段”、“程序数据段”、“程 序堆栈段”等
不错,这几种数据段都在其中,但除了以上几种数据段之外,进程还另外包含两种数据段
下面我们来简单归纳一下进程对应的内存空间中所包含的 5 种不同的数据区
代码段:代码段是用来存放可执行文件的操作指令,也就是说是它是可执行程序在内存种的镜像
代码段需要防止在运行时被非法修改,所以只准许读取操作,而不允许写入(修改)操作——它是不可写的
数据段:数据段用来存放可执行文件中已初始化全局变量,换句话说就是存放程序静态分配的变量和全局变量
BSS 段:BSS 段包含了程序中未初始化全局变量,在内存中 bss 段全部置零
堆(heap):堆是用于存放进程运行中被动态分配的内存段,它大小并不固定,可动态扩张或缩减
当进程调用 malloc 等函数分配内存时,新分配的内存就被动态添加到堆上(堆被扩张);当利用 free 等函数释放内存时,被释放的内存从堆中被剔除(堆被缩减)
栈:栈是用户存放程序临时创建的局部变量,也就是说我们函数括弧“{}”中定义的变量(但不包括 static 声明的变量,static 意味这在数据 段中存放变量)
除此以外在函数被调用时,其参数也会被压入发起调用的进程栈中,并且待到调用结束后,函数的返回值也回被存放回栈中