函数调用过程

来源:互联网 发布:linux 图片服务器搭建 编辑:程序博客网 时间:2024/06/06 13:00

函数调用过程

一个过程(Procedures)调用包括将数据(以过程参数和返回值的形式)和控制从代码的一部分传递到另一部分。

栈帧结构(Stack Frame Structure)

机器用来传递过程参数、存储返回值信息、保存寄存器用于以后恢复,以及本地存储。而为单个过程分配的那部分栈成为栈帧(stack frame)。如下图。

Alt text

假设过程P(调用者)调用过程Q(被调用者),则Q的参数放在P的栈帧中。当P调用Q时,P中的返回地址被压入栈中,形成P的栈帧的末尾。Q的栈帧从保存的帧指针的值开始,后面是保存的其他寄存器的值。

过程Q也用栈保存其他不能存放在寄存器中的局部变量。这样做的原因如下:
- 没有足够的寄存器存放所有的局部变量。
- 有些变量是数组或结构,所以必须使用数组或结构引用来访问。
- 要对一个局部变量使用地址操作符&,我们必须为他生成一个地址。

转移控制(Transferring Control)

指令 描述 call Label 过程调用 call OPerand 过程调用 leave prepare stack for return ret 从过程调用中返回

call指令用于将返回地址入栈,并跳转到被调用过程的起始处。

示例

以下面代码片为例所示,caller()函数中调用sqap_add(xp, yp)

int swap_add(int *xp,int *yp){    int x = *yp;    int y = *xp;    *xp = y;    *yp = x;    return x+y;}int cller(){    int arg1 = 534;    int arg2 = 1023;    int sum = swap_add(&arg1, &arg2);    int diff = arg1 - arg2;    return sum * diff;}

调用过程如下图所示。

Alt text

0 0
原创粉丝点击