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

简介: 打通你学习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上移

动态理解

简化版过程动图:

目录
相关文章
|
2月前
|
存储 编译器 程序员
C语言之反汇编查看函数栈帧的创建与销毁(一)
C语言之反汇编查看函数栈帧的创建与销毁(一)
C语言之反汇编查看函数栈帧的创建与销毁(一)
|
3月前
|
程序员 编译器 人机交互
深入学习《c语言函数》
深入学习《c语言函数》
36 0
|
3月前
|
编译器 Linux C语言
函数栈帧的创建和销毁(以C语言代码为例,汇编代码的角度分析)(上)
函数栈帧的创建和销毁(以C语言代码为例,汇编代码的角度分析)
|
3月前
|
算法 C语言
你会使用函数的递归和迭代吗?----------C语言函数学习(4)详解
你会使用函数的递归和迭代吗?----------C语言函数学习(4)详解
69 1
|
8天前
|
编译器 C语言
C语言指针学习
C语言指针学习
6 0
|
10天前
|
存储 编译器 C语言
C语言:底层剖析——函数栈帧的创建和销毁
C语言:底层剖析——函数栈帧的创建和销毁
|
12天前
|
存储 编译器 程序员
C语言学习大纲
C语言学习大纲
|
24天前
|
机器学习/深度学习 算法 C语言
C语言学习——打印各种图形
C语言学习——打印各种图形
24 0
C语言学习——打印各种图形
|
1月前
|
存储 编译器 C语言
C 语言函数栈帧的概念讲解
C 语言函数栈帧的概念讲解
16 0
|
2月前
|
存储 编译器 程序员
C语言之反汇编查看函数栈帧的创建与销毁(二)
C语言之反汇编查看函数栈帧的创建与销毁(二)