人生若只如初见:弄懂nginx与lua模块的交互。
以下内容是基于对可执行文件有着良好认识的前提下。
unix> ./p
p不是一个内置的命令,所以外壳会认为p是一个可执行目标文件,通过调用某个驻留在存储器中称为加载器(loader)的操作系统代码来运行它。
加载器将可执行目标文件中的代码和数据从磁盘拷贝到存储器中,然后跳转到程序的第一条指令或入口点(entry point)来运行该程序。
这个将程序拷贝到存储器并运行的过程叫做加载(loading).
存储器映像(a run-time memory image )
每个unix程序哦独有一个运行时存储器映像。
其中分为代码段、数据段、运行时堆。对于32位Linux系统,代码段总是从0x08048000开始,向上数据段是在接下来一个4KB对齐的地址。运行时堆则在接下来第一个4KB处,并通过malloc库往上增长。
用户栈总是从最大的合法用户地址开始。栈的上部开始的段是为操作系统驻留存储器的部分的代码和数据保留的。
根据可执行文件中段头部表,加载器将可执行文件的相关内容拷贝到代码和数据段。
加载器是如何工作的?
The new code and data segments are initialized to the contents of the executable file by mapping pages in the virtual address space to page-sized chunks of the executable file.
时间: 2025-01-04 07:51:48