函数栈帧问题
Posted 郭传瑞
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了函数栈帧问题相关的知识,希望对你有一定的参考价值。
函数调用另一个词语表示叫作过程。一个过程调用包括将数据和控制从代码的一部分传递到另一部分。另外,它还必须在进入时为过程的局部变量分配空间,并在推出时释放这些空间。而数据传递,局部变量的分配和释放通过操纵程序栈来实现。
栈帧(stack frame),机器用栈来传递过程参数,存储返回信息,保存寄存器用于以后恢复,以及本地存储。为单个过程(函数调用)分配的那部分栈称为栈帧。栈帧其实是两个指针寄存器,寄存器%ebp为帧指针,而寄存器%esp为栈指针,当程序运行时,栈指针可以移动(大多数的信息的访问都是通过帧指针的)。总之简单一句话,栈帧的主要作用是用来控制和保存一个过程的所有信息的。栈帧结构如下所示:
下面举个例子:
运行结果:正常返回到main函数中的调用的地方
修改一点代码:
运行结果:直接运行了bug函数,没有返回到main函数
简单画图分析一下:
那么在不使用y变量名称的情况下,如何改变y的内容?很简单了~首先要知道的是参数入栈顺序是从右向左的,即y在上,x在下,令p指向x,指针p++,则p指向了y,再用*p去改变y的值就可以了。
结果:
以上是关于函数栈帧问题的主要内容,如果未能解决你的问题,请参考以下文章