广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >c语言函数栈帧的创建和销毁过程详解
  • 845
分享到

c语言函数栈帧的创建和销毁过程详解

2024-04-02 19:04:59 845人浏览 薄情痞子
摘要

目录1 相关知识介绍 1.1 寄存器1.2 函数栈帧概述2 栈帧创建与销毁过程1 相关知识介绍  1.1 寄存器 一般计算机内通用寄存器包括eax,ebx,ec

1 相关知识介绍

 1.1 寄存器

一般计算机内通用寄存器包括eax,ebx,ecx,edx,esi,edi,esp,edp,其中esp,ebp这两个寄存器是用来存放地址的,这两个地址就是用来维护函数栈帧的

1.2 函数栈帧概述

我们知道C语言中函数都是被调用的,main函数里面能调用其他函数,其实main函数也是被别的函数调用的。main函数是在 _tmainCRTSartup 函数中被调用的,_tmainCRTSartup函数又是在mainCRTSartup函数中被调用。
每一次函数调用都是一个函数调用过程,这个过程要为函数开辟栈空间,用于本次函数的调用中临时变量的保存、现场保护,也叫函数栈帧。栈帧也叫过程活动记录,是编译器用来实现过程/函数调用的一种数据结构

push 压栈:给栈顶放上一个元素
pop 出栈:从栈顶删除一个元素

函数栈帧结构如下:
其中esp为栈顶指针,ebp为栈底指针,他们共同来维护函数栈帧。

在这里插入图片描述

2 栈帧创建与销毁过程

为了描述函数栈帧的创建和销毁我们以一个简单程序为例


#define _CRT_SECURE_NO_WARNINGS 1

#include <stdio.h>

int add(int x, int y)
{
	int z = 0;
	z = x + y;
	return z;
}
int main()
{
	int a = 20;
	int b = 10;
	int c = 0;
	c = add(a, b);
	printf("%d\n", c);
	return 0;
}

当进入main函数前,esp,ebp在如下位置

在这里插入图片描述

我们此时可以进入调试模式然后进入反汇编模式看下汇编代码从而观察main函数栈帧的创建

在这里插入图片描述
在这里插入图片描述

这里是将ebp压栈(用来记录上一个ebp方便函数销毁时找到上一个函数的位置),然后将esp的值传给ebp,在将esp的内容减去0E4h,从而为main函数创建了一个栈帧,并且将ebx,sei,edi的值进行压栈。效果如下

在这里插入图片描述
在这里插入图片描述

这里是将ebp-0E4h的值加载到edi里面,然后将39h放到ecx寄存器里,再将0CCCCCCCCh放到eax寄存器里,最后将edi这个地址下面的39h个字节数据的值全部置为CCCCCCCC.

在这里插入图片描述
在这里插入图片描述

这段汇编代码时将14h赋值到ebp-8的空间里面,将0Ah赋值到ebp-14h的空间里面,将0赋值到ebp-20h的空间里面.

在这里插入图片描述
在这里插入图片描述

然后进入c = add(a,b)语句,首先将ebp-14h的值放到eax寄存器中在将eax的值进行压栈操作,再将ebp-8的值放到ecx寄存器中在将ecx的值进行压栈操作。

下面图片中绿色框里eax应该是10,ecx是20,画图时写反了实在是抱歉

在这里插入图片描述
在这里插入图片描述

这里是跳转到add函数,并将下一条语句的地址压入栈内

在这里插入图片描述


000E17C0  push        ebp  //记录上一个ebp内容
000E17C1  mov         ebp,esp  //将esp的值赋给ebp
000E17C3  sub         esp,0CCh  //将0CCh赋给esp,为add创建栈帧
000E17C9  push        ebx  
000E17CA  push        esi  
000E17CB  push        edi  
000E17CC  lea         edi,[ebp+FFFFFF34h]  
000E17D2  mov         ecx,33h  
000E17D7  mov         eax,0CCCCCCCCh  
000E17DC  rep stos    dWord ptr es:[edi]  
000E17DE  mov         ecx,0EC003h  //与前面类似
000E17E3  call        000E1307  //进入add函数
     7: 	int z = 0;
000E17E8  mov         dword ptr [ebp-8],0  //将0赋给ebp-8的内容
     8: 	z = x + y;
000E17EF  mov         eax,dword ptr [ebp+8] //将a的值赋给eax寄存器
000E17F2  add         eax,dword ptr [ebp+0Ch]  //将b+a的值赋给eax
000E17F5  mov         dword ptr [ebp-8],eax  //将eax的值赋给ebp-8的内容里面
     9: 	return z;
000E17F8  mov         eax,dword ptr [ebp-8] //将ebp-8的内容里面赋给eax

在这里插入图片描述

至此add函数功能执行完成,接下来开始返回,也就是进行add函数栈帧销毁

在这里插入图片描述

首先分别将edi,esi,ebx进行出栈,然后将esp加上0CCh也就是回到ebp的位置,然后将ebp的值赋给esp,再将ebp进行出栈操作(这样就能回到原来的main函数的ebp位置从而将add的栈帧空间还给操作系统

在这里插入图片描述
在这里插入图片描述

后面是main函数的销毁过程,流程和add销毁一样,这里就不在过多赘述。

到此这篇关于c语言函数栈帧的创建和销毁的文章就介绍到这了,更多相关c语言函数栈帧内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: c语言函数栈帧的创建和销毁过程详解

本文链接: https://www.lsjlt.com/news/132317.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • c语言函数栈帧的创建和销毁过程详解
    目录1 相关知识介绍 1.1 寄存器1.2 函数栈帧概述2 栈帧创建与销毁过程1 相关知识介绍  1.1 寄存器 一般计算机内通用寄存器包括eax,ebx,ec...
    99+
    2022-11-12
  • C语言函数栈帧的创建和销毁详解
    目录写在前面Add函数的调用函数传参Add函数栈帧的创建Add函数栈帧的销毁main函数栈帧的销毁总结写在前面 我们知道,每一次函数调用都需要在栈区上为其开辟一块空间,这块空间就叫做...
    99+
    2022-11-13
  • C语言函数栈帧的创建与销毁详解
    目录前言一、函数栈帧是什么?1.寄存器2.ebp与esp二、函数栈帧的创建1.代码块2.调用堆栈3.esp与ebp如何维护栈帧总结 前言 大家在学习的时候一定有以下困惑: ...
    99+
    2022-11-13
  • C语言函数栈帧如何创建和销毁
    这篇文章主要为大家展示了“C语言函数栈帧如何创建和销毁”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“C语言函数栈帧如何创建和销毁”这篇文章吧。写在前面我们知道,每一次函数调用都需要在栈区上为其开...
    99+
    2023-06-29
  • C语言超详细讲解函数栈帧的创建和销毁
    目录1、本节目标2、相关寄存器3、相关汇编指令4、什么是函数栈帧5、什么是调用堆栈6、函数栈帧的创建和销毁(1)、main函数栈帧的创建与初始化(2)、main函数的核心代码(3)、...
    99+
    2022-11-13
  • C语言函数栈帧的创建和销毁介绍
    在初学c语言中,很多时候要记的内容有点多,有时候并不能深入的了解它。关于函数的栈帧可以帮助我们深入了解函数传参的过程,让我们了解c语言。 以下是我们平时接触过,但不了解的问题: 1...
    99+
    2022-11-12
  • C语言详尽图解函数栈帧的创建和销毁实现
    目录常见寄存器基本的汇编语言知识具体实现关于栈帧创建与销毁的问答题注:本文章所使用的编译器是VS2010,由于不同编译器的函数栈帧与销毁略有差异,所以具体细节请读者自行实践! 常见寄...
    99+
    2022-11-13
  • C语言函数栈帧的创建与销毁原理图解
    目录什么是函数栈帧什么是栈?与函数栈帧有关的汇编语句函数如何创建栈帧并销毁main函数栈帧开辟调用Add函数返回主函数什么是函数栈帧 我们在写C语言代码的时候,经常会把一个独立的功能...
    99+
    2022-11-13
  • C语言中函数栈帧的创建和销毁的深层分析
    目录一、本文目标二、基础知识1、寄存器2、代码案例  3、总体栈帧概况4、所需反汇编代码总览三、函数栈帧创建销毁过程1、_tmainCRTStartup函数(调用main函...
    99+
    2022-11-13
  • 如何进行C语言函数栈帧的创建和销毁分析
    如何进行C语言函数栈帧的创建和销毁分析,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。以下是我们平时接触过,但不了解的问题:1.为什么局部变量在未赋值前是随机的。2.局部变量...
    99+
    2023-06-22
  • 详细理解函C语言的函数栈帧
    目录一、函数栈帧的创建1.寄存器2.函数栈帧3.函数中调用函数二、函数栈帧的销毁总结一、函数栈帧的创建 1.寄存器 一般来说,计算机中的寄存器有六种 分别是:eax, ebx, e...
    99+
    2022-11-12
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作