过程(函数)调用时的栈(运行时栈)
运行时栈
每个进程都有自己的栈空间,x86-64的栈向低地址方向增长,而栈栈指针%rsp指向栈顶元素。可以使用pushq和popq(汇编指令)将数据存入栈中或是从栈中取出,将栈指针减小一个适当的量可以为没有指定初始值的数据在站上分配空间。类似地,可以通过增加栈指针来释放空间。当x86-64过程需要的存储空间超出寄存器能够存放的大小时,就会在栈上分配空间。这个部分称为过程的栈帧(stack fram)。
为了提供空间和时间效率,x86-64过程只分配自己所需要的的栈帧部分。例如许多过程有6个或者更少的参数,那么所有的参数都可以通过寄存器传递。因此,上图中画出的某些栈帧部分可以省略。实际上,许多函数甚至根本不需要栈帧。当所有的局部变量都可以保存在寄存器中,而且该函数不会调用任何其他函数(有时称为叶子过程,此时把过程调用功能看做树结构)时,就可以这样处理。
过程调用的汇编指令
函数(过程)调用的过程就是将参数及返回地址传入栈帧的过程,同时也将程序计数器转换到函数里面的第一条指令。
汇编指令中,call指令的作用就是调用一个过程,将返回地址(调用返回后的下一条指令地址)压入占中,设置程序计数器PC为过程的第一条指令的地址。而ret指令的作用是从过程中返回,它将从栈中弹出栈顶元素(此时是返回的指令地址,也即