打通你学习C语言的任督二脉-函数栈帧的创建和销毁(上)

 

🌈个人主页: Aileen_0v0
🔥系列专栏:C语言学习
💫个人格言:"没有罗马,那就自己创造罗马~"

待解决疑惑:

局部变量是怎么创建的?
为什么局部变量的值是随机值?
函数是怎么传参的?传参的顺序是怎样的?
形参和实参是什么关系?
函数调用是怎么做的?
函数调用是结束后怎么返回的?

1.寄存器 

寄存器是计算机中的一种内部存储器件。它是位于CPU内部的一组存储单元,用于暂时存储指令执行过程中的数据,如算术运算的操作数、地址等。寄存器的容量很小,通常只有几十个字节,但它的数据传输速度非常快,因此能够快速地完成指令的执行。寄存器的种类有很多,如通用寄存器、指令指针寄存器、程序计数器寄存器等。不同的指令需要使用不同类型的寄存器,这样可以提高计算机的运行效率。

C语言的寄存器包括:eax , ebx , ecx , edx , ebp , esp

函数栈帧

ebp ,esp 这两个寄存器中存放的是地址,这两个地址是用来维护函数栈帧的.

每一个函数调用,都要在栈区创建一个空间.

调用哪个函数,ebp和esp就维护哪个函数

演示代码

#define _CRT_SECURE_NO_WARNINGS
#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;
}

学习基础

在学习这个执行过程之前,我们需要找到反汇编 ,我们需要通过打断点运行并调试代码后在调试处,点击窗口然后就能够找到反汇编,此外我们还可以通过调试的监视窗口监视数据变化过程.

若对调试步骤有疑惑可以点击👉🔗:http://t.csdnimg.cn/nQiJn

 学习开始

首先,为main函数先开辟栈帧空间

根据逐步运行结果可以发现esp地址减小了,说明ebp被压入栈内,esp上移

move是 将esp的值给ebp

给esp的地址减0E4h

将ebx压入栈顶,esp上移

将esi压入栈顶,esp上移

将edi压入栈顶,esp上移

动态理解 

 简化版过程动图:

评论 25
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Aileen_0v0

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值