我们知道C语言中,每个栈帧对应着一个未运行完的函数。栈帧中保存了该函数的返回地址和局部变量。栈帧也叫过程活动记录,是编译器用来实现函数调用的一种数据结构。那么在Linux下gcc编译器栈帧是怎么实现的呢?
首先先来看一段程序:
猜猜程序运行的结果是什么?你会发现你的系统会立马重启。这是为什么呢,这就是程序运行的堆栈在作怪!!
下边这张图会让你很清楚的理解
分析:
1、首先函数在传参的时候使用的是值传递,在fun1中使用的参数并不是真正的参数,而是临时拷贝。
2、p得到参数a的地址,并且--得到call指令的下一条指令,p=fun()使得当前函数运行完成之后就,运行fun()函数。
那么现在再来看一看如何通过不使用b变量,来改变它的值
运行结果:
就这样讲b变量的值改变
有什么不足之处,希望大家批评指正