【汇编】esp寻址与ebp寻址

article/2025/10/4 8:23:08

前言:本教程使用的工具是DTDEBUG,讲解的是32位汇编。

1、什么是esp寻址

        顾名思义,使用esp这个栈顶指针寄存器去寻找变量对应的地址,就叫做esp寻址。

        如下就是一个简单的esp寻址:

        像这样,我们通过esp的偏移来寻找参数的地址,就叫做esp寻址。

        esp寻址的优缺点:

        优点:便捷

        缺点:当遇到复杂的、函数中对堆栈有操作的,esp寻址就会变得有些困难。 

        例如:

        我们之前的测试两数相加,都是把参数从堆栈中取出,放在寄存器里,但实际开发中,寄存器里的值一般情况下都是有用的,说到底就是我们不能直接取出寄存器里的值,我们需要将值备份一份,然后再寻址,使用完成之后再将原来的值取出,如下:

        这也就是esp寻址的缺点所在。

        因此,便有了ebp寻址。

2、什么是ebp寻址

        顾名思义,通过使用ebp寄存器来寻找变量的地址就叫做ebp寻址。

        ebp寻址的优缺点:

        优点:当遇到大量的堆栈操作的时候,寻址并不会变得困难

        缺点:如果只有少量的堆栈操作,ebp还是相对复杂的。 

        这里我们就使用两个参数进行ebp寻址,知道原理即可:

        此时的ebp和esp中间有十六个字节的堆栈是我们自己分配的一块内存,随便用,因为当我们把ebp中的值还给esp的时候,栈顶指针就相当于减了0x10 

        接下来我们将需要用到的寄存器中的值备份到ebp到esp之间的堆栈里:

        为什么不能将eax,push到esp上面的堆栈呢?

        加入我们备份寄存器中的值的时候,不使用ebp到esp之间的地址,我们使用push eax这个指令会怎么样呢?如下:

        我们需要保证函数使用F8执行之后eax里得到的是两个数相加的值,而不是在函数里边得到相加的结果,但是函数执行完了eax又变成原来的值了,这样的函数是没有意义的 

        所以,我们应该把eax被分到ebp到esp之间的堆栈,函数结束后在401219的位置将eax原来的值取出来:

   

       

        将esp的值还给esp,ebp的值还给ebp:

 

        然后返回,这里尽量使用外平栈,不要用retn 8

        因为我们之前将eax值被分到ebp也就是当前的esp+4的位置了,如果我们这个时候将栈顶指针再退两步,那么寻找eax原来的值就变麻烦了,所以先返回函数再取出eax备份,然后再外平栈

        如下:

       

        我们先执行完函数retn看看eax结果对不对:

 

        没有问题,函数的职责尽到了。

        然后取出eax里原来的值:

 

        也没有问题。

        最后外平栈:

 

        至此,ebp寻址完美结束。

总结:esp寻址是用于对堆栈进行少量操作的函数,ebp寻址适用于对对战进行大量操作且需要备份的函数。 

以上便是esp与ebp寻址的全部内容,如果有误望指出,以后大家一起进步。


http://chatgpt.dhexx.cn/article/fGXuZ0fu.shtml

相关文章

栈帧ebp,esp详解

栈帧%ebp,%esp详解 分类专栏: 汇编 首先应该明白,栈是从高地址向低地址延伸的。每个函数的每次调用,都有它自己独立的一个栈帧,这个栈帧中维持着所需要的各种信息。寄存器ebp指向当前的栈帧的底部(高地址&#xff0…

对于ESP、EBP寄存器的理解

转载:https://mp.weixin.qq.com/s/Od9X-qnQ3WWyZiLIS4uPFg 函数调用是编程语言都有的概念,也许你听说过函数调用栈,但是大家都知道函数调用是如何完成的吗?我们为什么要了解这个过程: 对于程序运行机制中的数据结构和实现的了解&…

ebpf简介

目录 什么是eBPFeBPF架构eBPF优势eBPF相关工具 什么是eBPF eBPF 是什么呢? 从它的全称“扩展的伯克利数据包过滤器 (Extended Berkeley Packet Filter)” 来看,它是一种数据包过滤技术,是从 BPF (Berkeley Packet Filter) 技术扩展而来的。顾…

函数栈EIP、EBP、ESP寄存器的作用

这一篇文章咱们就来重新认识一下EIP、EBP、ESP这三个寄存器,寄存器又好几个,但是为什么我们要单独看这几个呢?因为在很多情况下我们在调试的时候最注意的就是这三个寄存器,其实这几个寄存器都是为“栈”而生,下面将结合…

你了解函数调用过程吗?

函数调用是编程语言都有的概念,也许你听说过函数调用栈,但是大家都知道函数调用是如何完成的吗?我们为什么要了解这个过程: 对于程序运行机制中的数据结构和实现的了解,对自己开发程序有着启发作用碰到一些疑难杂症的时候&#x…

ebp/栈帧/call stack

一.什么是ebp? (1)ESP:栈指针寄存器(extended stack pointer),其内存放着一个指针,该指针永远指向系统栈最上面一个栈帧的栈顶。 (2)EBP:基址指针寄存器(extended base …

栈帧详解

一. 理解栈帧 栈帧是什么,我们基本的理解是栈帧是栈帧也叫过程 活动记录,是 编译器用来实现过程/ 函数调用的一种数据结构。通俗来说栈帧就时C语言函数在调用的过程中的调用原理,就是当我们执行一个函数操作的时候,它的内部是如何…

EBP 和 ESP 详解

基本概念: (1)ESP:栈指针寄存器(extended stack pointer),其内存放着一个指针,该指针永远指向系统栈最上面一个栈帧的栈顶。 (2)EBP:基址指针寄存器(extended base poin…

基于生命周期的开发方法——迭代开发方法

迭代开发方法 上一篇原型方法只是一种需求验证的手段,如果将其思想运用到整个开发过程,使得每个阶段的任务经过反复多次,或者将分析、设计、实施的周期反复多次,通过一次次迭代,不断在原来的基础上完善和修正&#xf…

2.迭代开发的过程是怎么样的

敏捷开发系列文章目录 在讨论PO如何给团队讲好故事这个问题之前,先给大家了解一些基本的敏捷概念,然后讲讲我们敏捷团队构成与整个敏捷开发的过程。 当初敏捷老师讲课的时候就跟我们所过,敏捷没有什么具体的形式,每个敏捷团队可能…

RUP之动态结构:迭代开发

迭代过程一般分为四个阶段:初始、细化、构造和移交,简称为I,E,C和T。每个阶段以一个重要的里程碑(milestone)结束。 初始(Inception)阶段 确定最终产品的构想及其业务用例、并定义项目范围 初始阶段以生命周期目标(LCO)里程碑为结束点 细化(Elaborat…

开发模式(敏捷开发,瀑布式开发,螺旋型开发,迭代开发,devOps开发)

一. 敏捷开发 以人为核心、迭代、循序渐进的开发方式 简化文档,提取文档重点,主要在于人与人之间的沟通, 对开发产品进行迭代,最终完成开发。 迭代:迭代是指把一个复杂且开发周期很长的开发任务,分解为很…

敏捷开发-快速迭代

(转自:http://blog.csdn.net/xiaoxian8023/article/details/8883791) 今天跟大家分享的是“敏捷开发、快速迭代”。我们大都采用的是“瀑布开发模式”,有了问题,就得返工,虽然最终的产品会比较齐全完善,但是…

一文搞定软件过程模型——瀑布模型、增量式开发/增量开发与迭代开发的区别

软件开发比较经典的过程模型有: 瀑布模型:该模型将基本的过程活动、描述、开发、有效性验证和进化,看成是一些界限分明的独立的过程阶段,例如,需求描述阶段、软件设计阶段、实现阶段、测试阶段等。增量式开发&#xf…

软件迭代开发流程

如果对python自动化测试、web自动化、接口自动化、移动端自动化、大型互联网架构技术、面试经验交流等等感兴趣的老铁们,可以关注我。我会在公众号(程序员阿沐)/群里(810119819)不定期的发放免费的资料链接&#xff0c…

迭代开发流程

转载于:https://www.cnblogs.com/gispathfinder/p/8747869.html

git 迭代开发分支流程规范

前言 Git 的名称太响了,相信大家都听说过,鼎鼎大名的同性交友网站 GitHub 就是基于 Git 作为唯一的版本库格式进行托管的平台。本篇不详细介绍 Git 的使用,仅介绍基于 Git 的开发分支流程规范,需要对 Git有一定的了解。 简述 G…

迭代开发和增量开发

(转自:http://blog.csdn.net/l12345678/article/details/5642851) “迭代”和“增量”是敏捷软件开发中的两个重要概念。弄清楚“迭代”和“增量”以及其依据,我们就可以在实际的操作中有章法可循。 为什么要迭代? 我们…

转」最佳方案:迭代式开发

前言 Fred Brooks 在 25 年前就曾写到:“不要指望一次成功,无论如何你都要这样。” 敏捷开发,小步快跑,持续迭代,不断改进,产品升级。 在用例需要之前,不要添加数据成员 在代码之前编写测试 …

alert意为:警告、警报。

在JavaScript代码中&#xff0c;alert的作用是弹出一个浏览器对话框&#xff0c;"JS代码"为提示对话框的内容 <body><script type"text/JavaScript"> alert("提交成功&#xff01;我会尽快与你取得联系"); </script></body…