现在PC平台的文件格式,主要是Windows下的PE和Linux的ELF,它们都是COFF格式的变种。COFF在目标文件里引入了段机制,不同的目标文件可以拥有不同数量及不同类型的段。
关于段式内存管理的分段:
Linux已经基本弃用了段式内存管理,段描述符表所有段基址都为0,大小为整个虚拟空间,直接把整个虚拟内存看成一整个段。也就是说,此处的内存分段只是用于糊弄CPU,与程序被映射到虚拟内存时划分的数据段、代码段等虚拟内存区域已经没有关系了。那么编译后的目标文件中分段的意义是什么。
主要有以下几个原因:
- 数据和指令被划分到两个虚拟内存区域,方便进行访问权限控制,防止程序指令被有意无意的改写。
- 对于现代CPU来说,有着极为强大的缓存体系,一般CPU的缓存被设计成数据缓存和指令缓存分离,所以分段有助于提高缓存命中率。
- 当系统运行着多个该程序的副本时,只需要保存一份指令部分。可以通过共享指令节省大量内存。
可执行文件与进程的虚拟空间的映射关系:
这种映射关系只是保存在操作系统内部的一个数据结构。Linux中将进程虚拟空间中的一个段叫做虚拟内存区域(VMA);在Windows中将这个叫做虚拟段(Virtual S