Linux - 函数的栈帧

Posted Sophie_h

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Linux - 函数的栈帧相关的知识,希望对你有一定的参考价值。

  栈帧(stack frame),机器用栈来传递过程参数,存储返回信息,保存寄存器用于以后恢复,以及本地存储。为单个过程(函数调用)分配的那部分栈称为栈帧。栈帧其实是两个指针寄存器,

寄存器%ebp为帧指针,而寄存器%esp为栈指针,当程序运行时,栈指针可以移动(大多数的信息的访问都是通过帧指针的)。总之简单一句话,栈帧的主要作用是用来控制和保存一个过程的

所有信息的。栈帧结构如下所示:

  下面,我们通过一个简单的程序来了解栈帧:

  简单的函数分析,如下图:

  该函数的栈帧情况

当*p=bug,修改栈帧中保存返回值的位置,使得函数不是正常返回,而是进入bug函数,当遇到exit函数,程序终止,不在跳回到main函数中终止。

以上是关于Linux - 函数的栈帧的主要内容,如果未能解决你的问题,请参考以下文章

c语言函数的栈帧

为啥ebx保存在一个简单函数的栈帧中,调用gets?

函数调用时的栈帧变化

浅谈main函数的栈帧

C语言函数调用及栈帧结构

函数栈帧详解