3分钟搞懂函数调用在内存中的实现

让我们来看这段代码在内存中的运行流程
void func2(){
int k=1;
return ;
}
void func1(){
int j=0;
func2();
return ;
}
int main(){
int i=0;
func1();
return ;
}

第一步:
假如操作系统目前正在执行某一程序,正执行到ad0地址
3分钟搞懂函数调用在内存中的实现第二步:
此时你运行了test程序,为了在test程序执行完毕之后能继续运行刚开始的程序那么必须在test程序执行完毕之后返回到s0地址,所以就要在main函数栈帧(栈帧就是一段栈内存)最下面保存s0的地址。当test程序启动时,文本代码被加载到内存的代码段(c语言内存管理机制中有一个堆区存放代码段),这时文本代码才被加载到内存,但还没有对函数各条指令进行压栈
3分钟搞懂函数调用在内存中的实现
第三步:
对各个函数内的指令进行压栈:
这个对函数的指令进行压栈的过程是操作系统去做的,操作系统去代码段寻找main函数代码段,首先对main函数进行压栈,再对func1进行压栈,再对func2进行压栈。ad1 是func1的指针处的地址,ad2是func2的指针的地址
3分钟搞懂函数调用在内存中的实现
第四步:
出栈(即指令执行过程)
当各个函数的栈帧建立好了,这个程序才真正的开始执行了,
通过地址总线把各条指令运送到cpu里面运行,每执行一条指令,
栈顶指针就往下移动一个字(一条指令的大小通常指一个字)
的大小

3分钟搞懂函数调用在内存中的实现
3分钟搞懂函数调用在内存中的实现
3分钟搞懂函数调用在内存中的实现
3分钟搞懂函数调用在内存中的实现
3分钟搞懂函数调用在内存中的实现
3分钟搞懂函数调用在内存中的实现
3分钟搞懂函数调用在内存中的实现
是不是只用了你三分钟