文章目录
- 虚拟内存
- 虚拟地址空间(其他 Unix 系统的设计也与此类似)。
- 程序代码和数据
- 堆
- 共享库
- 栈
- 内核虚拟内存
- 参考
虚拟内存
虚拟内存是一个抽象概念,它为每个进程提供了一个假象,即每个进程都在独占地使用主存。每个进程看到的内存都是一致的,称为虚拟地址空间。
虚拟地址空间(其他 Unix 系统的设计也与此类似)。
在 Linux 中,地址空间最上面的区域是保留给操作系统中的代码和数据的,这对所有进程来说都是一样。
地址空间的底部区域存放用户进程定义的代码和数据。
图中的地址是从下往上增大的:
程序代码和数据
对所有的进程来说,代码是从同一固定地址开始,紧接着的是和C全局变量相对应的数据位置。
代码和数据区是直接按照可执行目标文件的内容初始化的,在示例中就是可执行文件 hello。
堆
代码和数据区后紧随着的是运行时堆。代码和数据区在进程一开始运行时就被指定了大小,与此不同,当调用像 malloc 和 free 这样的 C标准库函数时,堆可以在运行时动态地扩展和收缩。
共享库
大约在地址空间的中间部分是一块用来存放像 C标准库和数学库这样的共享库的代码和数据的区域。共享库的概念非常强大,也相当难懂。
栈
位于用户虚拟地址空间顶部的是用户栈,编译器用它来实现函数调用。
和堆一样,用户栈在程序执行期间可以动态地扩展和收缩。特别地,每次我们调用一个函数时,栈就会增长。
从一个函数返回时,栈就会收缩。
内核虚拟内存
地址空间顶部的区域是为内核保留的。
不允许应用程序读写这个区域的内容或者直接调用内核代码定义的函数。相反,它们必须调用内核来执行这些操作。
参考
《深入理解计算机系统》