(自用)
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(...)。
本文通过反汇编分析,揭示了C/C++程序中main函数的执行过程,重点讲解了栈区、堆区和静态区的区别,以及在main函数中寄存器的使用和参数传递机制。
1811

被折叠的 条评论
为什么被折叠?



