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

 

个人主页: 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;
}

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

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

学习基础

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

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

 学习开始

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

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

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

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

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

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

move是 将esp的值给ebp

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

给esp的地址减0E4h

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

将ebx压入栈顶,esp上移

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

将esi压入栈顶,esp上移

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

将edi压入栈顶,esp上移

动态理解 

 简化版过程动图:打通你学习C语言的任督二脉-函数栈帧的创建和销毁(上)_第11张图片

 

你可能感兴趣的:(C语言学习,学习,c语言,开发语言,前端,算法,c#,个人开发)