1 进程内存布局
下图是一个32位Linux进程的内存空间分布图。
(1)保留区
从0开始到0x08048000这一段,属于保留区。实际上,这部分并不是个单一的内存区域,而是禁止用户进程访问的地址区域的总称,这段地址空间中受到操作系统保护。
如果这段内存区能操作的话,你的C代码中的空指针NULL也就合法了。所以,大多数操作系统中,极小的地址通常都是不允许访问的。C语言将无效指针赋值为0(NULL)也是出于这种考虑,因为0地址上正常情况下不会存放有效的可访问数据。
(2)代码段(text)
通常用于存放程序执行代码(即CPU执行的机器指令)。指令中包括操作码和操作对象(或对象地址引用),如果操作对象是立即数,直接会包含在本区代码段中;若是局部数据,将在栈区分配空间,然后引用该数据地址;若位于BSS段和数据段,指令会引用该数据地址。
(3)数据段(Data)
如果程序的数据是全局变量,并且定义的同时有初始化值。这样的变量,就存储在数据段。然后在进程在加载,这一段的内存就被复制到相应的内存。
当程序读取数据段的数据时,系统会触发缺页故障,从而分配相应的物理内存;当程序读取BSS段的数据时,内核会将其转到一个全零页面,不会发生缺页故障,也不会为其分配相应的物理内存。
(4)BSS段
没有初始化的全局变量会被加载到此段内存区。<