函数调用过程解析图(函数栈帧)

来源:互联网 发布:淘宝自带的折扣工具 编辑:程序博客网 时间:2024/06/13 20:46

函数调用过程:为函数开辟栈空间,用于本次函数的调用中临时变量的保存、现场保护。
我们最熟悉的莫过于程序入口函数main函数,main函数是在__tmainCRTStartup中调用;而__tmainCRTStartup函数是在mainCRTStartup中调用。调用过程中产生的栈空间称之为函数栈帧。
栈帧维护需要esp和ebp寄存器:
这里写图片描述
esp寄存器存放指向函数栈帧栈顶的指针;ebp寄存器存放指向函数栈帧栈底的指针。
栈空间是从高地址向低地址增长,用来保存函数栈帧。
下来就具体分析一下函数调用过程:

#include <stdio.h>int Sub(int x, int y){    int m = 0;    m = x - y;    return m;}int main(){    int ret = 7;    int tmp = 4;    int t = 0;    t=Sub(ret, tmp);    printf("%d", t);    return 0;

1.对汇编代码进行分析:
这里写图片描述

2.函数栈帧在内存中的分布情况:

这里写图片描述

3.函数的返回
函数调用过程对应着调用栈的建立,而函数返回则是进行调用栈的销毁。先将edi,esi,ebx三个寄存器出栈,然后根据记录的call指令的下一条指令的地址找到main函数,回收空间,完成整个函数调用的过程。

原创粉丝点击