首先通过下面这段代码探究函数的调用过程: #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函数 到这里一个函数就调用完了,如果这篇博客哪里有写的不对的地方,希望大家可以指出来。