一、运行时栈
可执行文件的存储映像
在 32 位机器中,指针 %esp 指向栈顶,在 64 位机器中,指针 %rsp 指向栈顶。x86-64 的栈向低地址方向存储。也就是说,如果给这个栈分配空间,那么栈顶指针的值减小。
当 x86-64 过程中,需要的存储空间超过寄存器能够存放的大小时,就会在栈上分配空间,这个部分成为过程的栈帧(stack fram)。大多数过程的栈帧都是定长的。
为了提高空间和时间的效率,x86-64 值分配自己所需要的栈帧部分。例如,许多过程有六个或更少的参数,那么所有的参数都可通过寄存器来传递。
下图中的某些栈帧部分其实时可以省略的。当所有的局部变量都可以用寄存器保存,而且该函数不会调用其他函数,这个函数甚至根本不需要栈帧。