C语言_函数的调用过程(栈帧)

首先通过下面这段代码探究函数的调用过程:

#include <stdio.h>
#include <stdlib.h>

int add(int a, int b)
{
    int ret = 0;
    ret = a + b;
    return ret;
}

int main ()
{
    int a = 10;
    int b = 20;
    int ret = 0;
    ret = add(a, b);
    printf ("a + b = %d\n", ret);
    system ("pause");
    return 0;
}

一、当程序开始运行时,查看调用堆栈:

如下图:

这里写图片描述

从图中可以看到main函数是在__tmainCRTStartup 函数中调用的,而__tmainCRTStartup是在函数mainCRTStartup中被调用的。

我们知道每一次函数调用都是一个过程,这个过程我们称之为函数的调用过程。

在这个过程中,要为函数开辟栈空间,用于本次函数的调用中临时变量的保存、现场保护,这块栈空间我们称之为函数栈帧。

而栈帧的维护我们必须了解ebp和esp这两个寄存器。在函数调用过程中,这两个寄存器存放了维护这个栈的栈底指针和栈顶指针。

比如: 调用main函数,我们为main函数分配栈帧空间,那么栈帧维护如下:

这里写图片描述

esp存放指向栈顶的指针

ebp存放指向栈底的指针

二、要想研究函数的详细调用过程,就得对应的汇编代码:

1、从main函数开始的地方,要展开main函数的调用就得为main函数创建栈帧。

这里写图片描述

2、接下来是add函数的调用,参数传递过程:

这里写图片描述

3、add函数的栈帧

这里写图片描述

4、回到main函数

这里写图片描述

到这里一个函数就调用完了,如果这篇博客哪里有写的不对的地方,希望大家可以指出来。

猜你喜欢

转载自blog.csdn.net/a__b__c__/article/details/80042476