函数栈帧的创建和销毁

本文通过反汇编分析,揭示了C/C++程序中main函数的执行过程,重点讲解了栈区、堆区和静态区的区别,以及在main函数中寄存器的使用和参数传递机制。

(自用)

main函数也是被调用后才执行的。

>    test_3_34.exe!main(...) 行 11    C
mian函数被exe!main(...)调用,然后执行mian函数。

栈区是由系统分配的内存,堆区是程序员自己动态分配的空间,静态区是全局变量存放的地方。

而给mian函数分配的空间自然也就在栈区,又叫mian函数的栈帧。

以上是执行mian函数的反汇编,第一部分是给mian函数分配空间,创建好后才开始执行main中的函数。

创建了两个寄存器rdi和rcx,rdi是小地址所以在上面

rsp和rbp是起保护作用,rsp和rbp中间的空间就是main函数的栈帧。rbp是栈顶,rsp是栈底

后赋予随机变量将分配的空间都赋值为cc

将rsp+4的地址赋值0,rsp+24的地址赋值0

关键在于进入Add函数

又创建了edx和ecx两个寄存器,暂时储存a和b的值,这里就是常说的形参,用完后自定义函数会销毁但寄存器却不会,因此可以传值

最后return出去,值return给了exe!main(...)。

下载前可以先看下教程 https://pan.quark.cn/s/16a53f4bd595 小天才电话手表刷机教程 — 基础篇 我们将为您简单的介绍小天才电话手表新机型的简单刷机以及玩法,如adb工具的使用,magisk的刷入等等。 我们会确保您看完此教程后能够对Android系统有一个最基本的认识,以及能够成功通过magisk root您的手表,并安装您需要的第三方软件。 ADB Android Debug Bridge,简称,在android developer的adb文档中是这么描述它的: 是一种多功能命令行工具,可让您与设备进行通信。 该命令有助于各种设备操作,例如安装调试应用程序。 提供对 Unix shell 的访问,您可以使用它在设备上运行各种命令。 它是一个客户端-服务器程序。 这听起来有些难以理解,因为您也没有必要去理解它,如果您对本文中的任何关键名词产生疑惑或兴趣,您都可以在搜索引擎中去搜索它,当然,我们会对其进行简单的解释:是一款在命令行中运行的,用于对Android设备进行调试的工具,并拥有比一般用户以及程序更高的权限,所以,我们可以使用它对Android设备进行最基本的调试操作。 而在小天才电话手表上启用它,您只需要这么做: - 打开拨号盘; - 输入; - 点按打开adb调试选项。 其次是电脑上的Android SDK Platform-Tools的安装,此工具是 Android SDK 的组件。 它包括与 Android 平台交互的工具,主要由构成,如果您接触过Android开发,必然会使用到它,因为它包含在Android Studio等IDE中,当然,您可以独立下载,在下方选择对应的版本即可: - Download SDK Platform...
C语言函数创建销毁与程序在内存中的执行过程紧密相关。以如下代码为例进行讲解: ```c #include<stdio.h> int Add(int x, int y) { int z = 0; z = x + y; return z; } int main() { int a = 10; int b = 20; int c = 0; c = Add(a, b); printf("%d\n", c); return 0; } ``` ### 函数创建 在程序执行时,每个函数在调用时都会在创建一个,用于保存该函数的局部变量、参数、返回地址等信息。当调用`main`函数时,会为`main`函数创建一个。在`main`函数中定义局部变量`a`、`b`、`c`,这些变量会被存储在`main`函数中。当调用`Add`函数时,会进行以下操作: - **参数传递**:函数的参数并未在函数创建,而是通过压操作放到`Add`函数底的下面位置。例如,`Add(a, b)`调用时,会将实参`a``b`的值进行压操作,传递给`Add`函数。这里的形参其实是实参的一份拷贝,对形参的修改不会影响实参 [^2][^3]。 - **保存返回地址**:记录调用`Add`函数结束后要返回的`main`函数中的位置,以便`Add`函数执行完毕后能回到正确的位置继续执行。 - **创建**:为`Add`函数创建新的,在这个中会保存`Add`函数的局部变量,如`z`。 ### 函数销毁函数执行完毕后,会进行销毁操作。以`Add`函数为例,执行完`return z`语句后: - **恢复寄存器状态**:将寄存器的值恢复到调用`Add`函数之前的状态。 - **释放局部变量空间**:释放`Add`函数中为局部变量分配的空间,如`z`。 - **恢复返回地址**:从中取出之前保存的返回地址,程序跳转到该地址继续执行,也就是回到`main`函数中调用`Add`函数的下一条语句继续执行。 - **释放参数空间**:释放之前压的参数所占用的空间。 函数在递归调用时,就是把`Add`函数看成新的`main`函数,不断重复创建工作。如果递归调用太多层,会不断创建新的,最终导致空间耗尽,引发 stack overflow(溢出) [^2]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值