c++函数调用堆栈的全过程

本文介绍了C++函数调用过程中堆栈的操作,包括寄存器的作用、栈帧的开辟、参数传递、返回值处理以及不同调用约定的影响。在函数调用时,系统会为函数创建栈帧,通过ebp和esp寄存器管理栈,内置类型参数通过寄存器传递,自定义类型可能涉及栈上拷贝。返回时,根据调用约定决定形参内存的清理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

要理解函数调用堆栈的过程,首先要对汇编指令和寄存器有一定的了解。我们简单介绍几个:

寄存器

  1. ebp:保存栈底指针的地址    
  2. esp:保存栈顶指针的地址    
  3. pc:存储下一行指令的地址
  4. eax,ebx:保存变量的值

汇编指令

  1. mov :移值
  2. lea:移地址
  3. rep stos 循环拷贝

在进入一个函数的时候,系统首先会为主函数开辟一段栈帧空间,空间开辟的大小一般为十六进制的4c但也不是国定不变的,主要取决于定义变量的所需内存大小。首先把ebp寄存器的值压栈,然后将ebp减去4c大小的空间赋给esp,再将其压栈这样,再内存中就有了一段大小为4c的主函数栈帧空间开始执行主函数中的指令

当执行到一个函数的调用处时,会重复上面的过程,要注意这里首先是传参而不是给被调用函数开辟zhan栈帧空间,传递参数的值时,如果参数类型是内置类型也就是int,char,float等这些等这些基本类型时,直接用寄存器dai'带入,见上图,如果是自定义类型则会按照其类型的大小分为两种不同的情况,

  • 如果其字节数大于8时,会在主函数的栈顶开辟一段内存,进行内存的拷贝
  • 如果小于8个字节就用寄存器带入。

接下来就进入到被调用函数体中,首先为其分配内存空间,即将esp寄存器的值赋给ebp寄存器,相当于ebp上移到主函数栈顶也就是bei'被调用函数栈底,再对esp进行-=运算,让其向上偏移指定大小的空间,再进行内存拷贝,将被调用函数的空间全部拷贝成拷贝成0cccccccc(相当于初始化的过程),然后再执行这个被调函数里面的指令。执行完之后如果函数的返回值类型是内

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值