个人主页: Aileen_0v0
系列专栏:C语言学习
个人格言:"没有罗马,那就自己创造罗马~"
待解决疑惑:
局部变量是怎么创建的?
为什么局部变量的值是随机值?
函数是怎么传参的?传参的顺序是怎样的?
形参和实参是什么关系?
函数调用是怎么做的?
函数调用是结束后怎么返回的?
1.寄存器
寄存器是计算机中的一种内部存储器件。它是位于CPU内部的一组存储单元,用于暂时存储指令执行过程中的数据,如算术运算的操作数、地址等。寄存器的容量很小,通常只有几十个字节,但它的数据传输速度非常快,因此能够快速地完成指令的执行。寄存器的种类有很多,如通用寄存器、指令指针寄存器、程序计数器寄存器等。不同的指令需要使用不同类型的寄存器,这样可以提高计算机的运行效率。
C语言的寄存器包括:eax , ebx , ecx , edx , edp , esp
函数栈帧
edp ,esp 这两个寄存器中存放的是地址,这两个地址是用来维护函数栈帧的.
每一个函数调用,都要在栈区创建一个空间.
调用哪个函数,ebp和esp就维护哪个函数
演示代码
#define _CRT_SECURE_NO_WARNINGS #include
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; }
学习基础
在学习这个执行过程之前,我们需要找到反汇编 ,我们需要通过打断点运行并调试代码后在调试处,点击窗口然后就能够找到反汇编,此外我们还可以通过调试的监视窗口监视数据变化过程.
若对调试步骤有疑惑可以点击:http://t.csdnimg.cn/nQiJn
首先,为main函数先开辟栈帧空间
根据逐步运行结果可以发现esp地址减小了,说明ebp被压入栈内,esp上移
move是 将esp的值给ebp
给esp的地址减0E4h
将ebx压入栈顶,esp上移
将esi压入栈顶,esp上移
将edi压入栈顶,esp上移