首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

【汇编语言】call 和 ret 指令(一) —— 探讨汇编中的ret和retf指令以及call指令及其多种转移方式

call 和ret 指令都是转移指令,它们都修改IP,或同时修改CS和IP。它们经常被共同用来实现子程序的设计。这一章,我们讲解call和ret指令的原理。...1. ret 和 retf 1.1 ret 指令 1.1.1 功能与理解 ret指令用栈中的数据,修改IP的内容,从而实现近转移。...call指令经常跟ret指令配合使用,因此CPU执行call指令,进行两步操作: (1)将当前的 IP 或 CS和IP 压入栈中 (2)转移 call 指令不能实现短转移,除此之外,call指令实现转移的方法和...下面的几个内容中 ,我们以给出转移目的地址的不同方法为主线,讲解call指令的主要应用格式。 3....转移地址在内存中的call指令 转移地址在内存中的call指令有两种格式: (1)call word ptr 内存单元地址 (2)call dword ptr 内存单元地址 6.1 字大小的内存形式 6.1.1

31510

汇编语言中的call指令和ret指令

call指令是调用函数的意思,让处理器从新的内存地址开始执行,过程使用RET来返回,让处理器回到调用点上。 call会将返回地址压入堆栈,然后再将要被调用的地址复制到IP寄存器里。...当RET指令被执行的时候,就会从堆栈中弹出返回地址到IP寄存器内。 调用和返回示例 假设在 main 过程中,CALL 指令位于偏移量为 0000 0020 处。...ret MySub ENDP 当 CALL 指令执行时如下图所示,调用之后的地址(0000 0025)被压入堆栈,MySub 的地址加载到 EIP。...执行 MySub 中的全部指令直到 RET 指令。当执行 RET 指令时,ESP 指向的堆栈数值被弹岀到 EIP(如下图所示,步骤 1)。...在步骤 2 中,ESP 的数值增加,从而指向堆栈中的前一个值(步骤 2)。

1.3K40
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【汇编语言】外中断(三)—— 探秘汇编外中断:从安装新INT 9例程到指令系统总结

    但仅仅从课程的角度出发就太片面了,其实学习汇编语言可以深入理解计算机底层工作原理,提升代码效率,尤其在嵌入式系统和性能优化方面有重要作用。...1.2 分析问题 1.2.1 改变屏幕的显示颜色 怎么改变屏幕的颜色呢? 学习win 32 的朋友立马百度:有相应的函数吗?...bx,2 loop s int9ret: pop es pop cx pop bx pop ax iret int9end: nop code ends end start 2....3.2 算术运算指令 比如:add、sub、adc、sbb、inc、dec、cmp、imul、idiv、aaa等都是算术运算指令,这些指令实现寄存器和内存中的数据的算数运算。...比如:call、ret、retf; (5)中断,比如int、iret。

    3500

    js中==和===有什么不同之处

    javaScript具有严格和类型转换相等比较。 对于严格相等比较符,要求比较的对象必须具有相同的类型,并且: 两个字符串在相应位置具有相同的字符序列,相同的长度和相同的字符时严格相等。...如果两个对象引用相同的对象,则它们严格相等。 Null和Undefined类型==正确(但使用===时不正确)。...Undefined)为false] 简单来说: == 代表相同, ===代表严格相同, 为啥这么说呢,  这么理解: 当进行双等号比较时候: 先检查两个操作数数据类型,如果相同, 则进行===比较, 如果不同..., 则愿意为你进行一次类型转换, 转换成相同类型后再进行比较, 而===比较时, 如果类型不同,直接就是false....操作数1 == 操作数2,  操作数1 === 操作数2 比较过程:   双等号==:    (1)如果两个值类型相同,再进行三个等号(===)的比较   (2)如果两个值类型不同,也有可能相等,需根据以下规则进行类型转换在比较

    2K30

    Python中的列表和Java中的数组有什么不同?

    Python中的列表和Java中的数组在多种编程语言中都是常见的数据结构。虽然两者在某些方面有相似之处,但也存在许多显著的区别。...下面将对Python中的列表和Java中的数组进行比较,以帮助理解它们之间的差异。 1、类型限制 Java中的数组具有固定的数据类型,例如整数、字符或浮点数等。...而Python中的列表可以包含任何类型的数据,如整数、字符串、布尔值、函数,甚至是其他列表和元组等。虽然与Java不同,但这使得Python列表非常灵活。...而Python中的列表则由一些结构体组成,在每个结构体中包含对元素的引用以及其他信息,因此即使存在间隙,也适用于灵活性和扩展性。...相比之下,Java只提供了有限的功能,例如填充数据、查找最大最小值等。 虽然Python中的列表和Java中的数组都是用于存储和操作数据的集合结构,但Python感觉更自由并且更灵活。

    17010

    16汇编第十讲完结Call变为函数以及指令的最后讲解

    整体的栈是这样的,这里为什么要一开始把bp和sp相等,是有原因的,我们不妨这样想,如果我们申请局部变量空间的 时候,是不是参数的偏移也要改动,这样每次都要自己计算偏移,相当麻烦,所以只能这样, 我们以后找参数就...返回 ,retf下面详细讲 在这里主要是掌握bp所在的位置即可,就能明白为什么这样写了,不信的话自己写个程序,看下反汇编,大体的就是这个套路,这里讲解的是为什么这样做,不是和市面的汇编视频一样,你看到...4到栈底才可以 二丶中断指令 1.什么是中断指令 中断,是有一种改变程序执行顺序的方法 中断具有很多的中断类型 中断的指令有3条   1.INT i8(i8代表一个八位的立即数)   2.IRET  IRET...和Call差不对,Call的ret返回的时候会把栈顶的元素弹出两个字节,这两个字节是返回地址,所以可以回到正确的地方执行指令,但是IRET明显比ret保存的东西多,其中ret我们可以手工的pop和jmp...F就会计算浮点数了 浮点数有7个寄存器 ST -> st7 按照标号来的 浮点处理器的st不能和通用寄存器一样去使用,它是吧ST寄存器压入栈中,让前两个栈中的数据相加返回的 关于浮点处理,后面再说,这个不是

    944100

    Java 中的 final、finally、finalize 有什么不同?

    Java 中 final、finally、finalize 有什么不同?这是在 Java 面试中经常问到的问题,他们究竟有什么不同呢?...这三个看起来很相似,其实他们的关系就像卡巴斯基和巴基斯坦一样有基巴关系。 那么如果被问到这个问题该怎么回答呢?...首先可以从语法和使用角度出发简单介绍三者的不同: final 可以用来修饰类、方法、变量,分别有不同的意义,final 修饰的 class 代表不可以继承扩展,final 的变量是不可以修改的,而 final...另外,有一些常被考到的 finally 问题。比如,下面代码会输出什么?...finalize 对于 finalize,是不推荐使用的,在 Java 9 中,已经将 Object.finalize() 标记为 deprecated。 为什么呢?

    88421

    Linux内核27-优化和内存屏障

    memory关键字强迫编译器假设RAM中所有的位置都被汇编指令更改了;因此,编译器不会使用CPU寄存器中的值优化asm指令之前的代码。...架构相关的内存屏障实现 X86系统中,下面这些汇编指令都是串行的,可以充当内存屏障: 所有操作I/O端口的指令; 前缀lock的指令; 所有写控制寄存器,系统寄存器或debug寄存器的指令(比如,cli...和sti指令,可以改变eflags寄存器的IF标志); lfence、sfence和mfence汇编指令,分别用来实现读内存屏障、写内存屏障和读/写内存屏障; 特殊的汇编指令,比如iret指令,可以终止中断或异常处理程序...ARM系统中,使用ldrex和strex汇编指令实现内存屏障。 3. Linux内核使用的内存屏障原语 Linux内核中使用的内存屏障原语如下,如表5-6所示。...smp_xxx()之类的内存屏障只对发生在多核系统里的竞态条件有效,单核系统中,什么也没有做。其它的内存屏障对多核系统和单核系统都有效。

    1.4K10

    深度模型中的优化(一)、学习和纯优化有什么不同

    1、学习和纯优化有什么不同用于深度模型训练的优化算法与传统的优化算法在几个方面有所不同。机器学习通常是间接作用的。在大多数机器学习问题中,我们关注某些性能度量P,其定义域测试集上并且可能是不可解的。...监督学习中, 是目标输出, 的变量是 和 。不难将这种监督学习扩展成其他形式,如包括 或者 作为参数,或是去掉参数 ,以发展不同形式的正则化或是无监督学习。...一般的优化和我们用于训练算法的优化有一个重要不同,训练算法通常不会停止在局部极小点。反之,机器学习通常优化代理损失函数,但是在基于提前终止的收敛条件满足停止。...4、批量算法和小批量算法机器学习算法和一般优化算法不同的一点是,机器学习算法的目标函数通常可以分解为训练样本上的求和。...第二次遍历时,估计将会是有偏的,因为它重新抽取了已经用过的样本,而不是从和原先样本相同的数据生成分布中获取新的无偏的样本。我们不难从在线学习的情况中看出随机梯度下降最小化泛化误差的原因。

    3.7K30

    DOS汇编程序提高练习

    3、CLI和STI总结 CLI汇编指令全称为Clear Interupt,该指令的作用是禁止中断发生,在CLI起效之后,所有外部中断都被屏蔽,这样可以保证当前运行的代码不被打断,起到保护代码运行的作用。...STI汇编指令全称为Set Interupt,该指令的作用是允许中断发生,在STI起效之后,所有外部中断都被恢复,这样可以打破被保护代码的运行,允许硬件中断转而处理中断的作用。...Audio In" =03H——声音产生芯片 出口参数: 无 ​ 有了前几次实验的经历,这次的实验写起来也相对地熟练一些,这次汇编程序的编写和提高的实验也带给我了很多的收获,通过实践的方法使用了...在第一个实验中,我认真读了实验资料中的几个串操作类指令的例子,通过这些例子,我大概有了关于复制并显示字符串的思路,我按照思路先画出了实验的流程图,并且通过MOVSB、REP指令写出了程序的实现片段,然后就面临着两个实验共有的问题...,掌握了CLI 指令:即禁止中断发生,在CLI起效之后,所有外部中断都被屏蔽,保证当前运行的代码不被打断,起到保护代码运行的作用,和STI指令:即允许中断发生,在STI起效之后,所有外部中断都被恢复,以打破被保护代码的运行

    88920

    汇编语言指令大全(详细)「建议收藏」

    汇编语言指令大全 8080汇编手册数据传输指令 ────────────────────────────── 它们在存贮器和寄存器、寄存器和输入输出端口之间传送数据。 1。 通用数据传送指令。...以上四条,测试带符号整数运算的结果(标志S,O和Z)。 JE/JZ 等于转移。 JNE/JNZ 不等于时转移。 JC 有进位时转移。 JNC 无进位时转移。 JNO 不溢出时转移。...4>中断指令 INT 中断指令 INTO 溢出中断 IRET 中断返回 5>处理器控制指令 HLT 处理器暂停, 直到出现中断或复位信号才继续。...二.需要熟练掌握的全部汇编知识(只有这么多) 不大容易理解,可先强行背住,混个脸儿熟,以后慢慢的就理解了 cmp a,b 比较a与b mov a,b 把b的值送给a ret 返回主程序 nop 无作用,...以上四条,测试带符号整数运算的结果(标志S,O和Z). JE/JZ 等于转移. JNE/JNZ 不等于时转移. JC 有进位时转移. JNC 无进位时转移. JNO 不溢出时转移.

    5.6K52

    前端问答:JavaScript 中的??和|| 有啥不同

    (空值合并运算符)和 ||(逻辑或运算符)。一开始看,它们似乎都能达到相同的效果,但其实它们背后的逻辑完全不同,适用的场景也不一样。今天我们就来聊聊这两者的区别,帮你快速上手,避免掉坑!...那什么时候用 "||" 呢? || 的最佳使用场景就是当你不确定一个值是否靠谱的时候,你可以为它准备一个备用值。就像生活中你遇到的两手准备:如果第一种方案失败了,立刻执行第二种。...(空值合并运算符)和 ||(逻辑或运算符)都是用来设置默认值的利器,初学者可能觉得它们差不多,但其实它们的行为有很大不同。为了避免代码里的坑,我们必须清楚两者的使用场景和差异。 1....|| 和 ?? 都使用了 短路求值,意思是如果左边的值能决定结果,右边的值就不会被计算。但两者的判断标准不同——|| 会在遇到任意“假值”时短路,而 ??...如果你觉得今天的内容对你有帮助,记得点个 在看 或 分享 给身边的小伙伴哦!

    22600

    NASM汇编_nasm标准

    (在不同模式下面,对应不同的寄存器,如32bit模式,对应32位寄存器) POPA 把DI,SI,BP,SP,BX,DX,CX,AX依次弹出堆栈....LODS的逆过程。把AL或AX或EAX中的数据装入目标串中。...REPNC 当CF=0且CX/ECX0时重复 程序转移指令 1. 无条件转移指令 JMP 无条件转移指令 CALL 过程调用 RET/RETF过程返回. 2....以上四条,测试带符号整数运算的结果(标志S,O和Z). JE/JZ 等于转移. JNE/JNZ 不等于时转移. JC 有进位时转移. JNC 无进位时转移. JNO 不溢出时转移....中断指令 INT 中断指令 INTO 溢出中断 IRET 中断返回 处理机控制指令 标志处理指令 CLC(进位位置0指令) CMC(进位位求反指令) STC(进位位置为1指令) CLD(方向标志置1

    62230

    腾讯的负载均衡和自己搭建的有什么不同

    宕机了,client 是无法提前感知到的,那么很可能 client 会连接到这台挂掉的 server 上,所以选择哪台机器来连接的工作最好放在 server 中,具体怎么做呢,在架构设计中有个经典的共识...:没有什么是加一层解决不了的,如果有那就再加一层,所以我们在 server 端再加一层,将其命名为 LB(Load Balance,负载均衡),由 LB 统一接收 client 的请求,然后再由它来决定具体与哪一个...这样的设计持续了很长一段时间,但是后来李大牛发现这样的设计其实还是有问题,不管是动态请求,还是静态资源(如 js,css文件)请求都打到 tomcat 了,这样在流量大时会造成 tomcat 承受极大的压力...,其实对于静态资源的处理 tomcat 不如 Nginx,tomcat 每次都要从磁盘加载文件比较影响性能,而 Nginx 有 proxy cache 等功能可以极大提升对静态资源的处理能力。...画外音:所谓的 proxy cache 是指 nginx 从静态资源服务器上获取资源后会缓存在本地的内存+磁盘中,下次请求如果命中缓存就从 Nginx 本机的 Cache 中直接返回了 所以李大牛又作了如下优化

    95340

    Java中抽象类(abstract class)和接口(interface)有什么不同?

    Java 中的抽象类(abstract class)和接口(interface)是两种常见的抽象化机制,它们都可以被用于定义一些具有一定抽象特性的东西,例如 API 或者系统中的某些模块。...尽管抽象类和接口有着相似之处,但也有明显的区别。下面将详细介绍这两个概念的不同点。 1、抽象类 抽象类是指不能直接实例化的类,只能被用来派生其他类,它被设计成为仅包含可继承的方法、属性和变量。...2、接口 接口和抽象类一样也是一种特殊类型的类,它仅声明了一组或者多组方法以及常量,可以被看作是一个对外公开的 API 契约。接口在 Java 中属于比抽象类更加抽象的概念。...3、抽象类和接口的区别 抽象类和接口都可以理解为一种模板或契约,它们之间虽然有相似点,但也存在很多不同之处。...(2)、abstract class 可以包含非抽象方法,而 interface 中的所有方法都默认为抽象方法。

    54620

    【汇编语言】int指令(一)—— 中断与栈的联动机制:透视int与iret的核心原理

    1. int 指令 中断信息可以来自CPU的内部和外部,当CPU的内部有需要处理的事情发生的时候,将产生需要马上处理的中断信息,引发中断过程。在前面一个章节中,我们讲解了中断过程和两种内中断的处理。...这一章中,我们讲解另一种重要的内中断。 是什么呢? 那就是DOS时代大名鼎鼎的int中断。 1.1 格式以及功能 int指令的格式为: int n,n为中断类型码。它的功能是引发中断过程。...用汇编语法描述,iret指令的功能为: pop IP pop CS popf CPU执行int 7ch指令进入中断例程之前,标志寄存器、当前的CS和IP被压入栈中,在执行完中断例程后,应该用iret指令恢复...✍int指令和 iret指令的配合使用与call指令和ret指令的配合使用具有相似的思路。 2.2 实例二 2.2.1 问题 问题:编写、安装中断7ch的中断例程。...可以利用iret指令,我们将栈中的se的偏移地址加上bx中的转移位移,则栈中的 se的偏移地址就变为了s的偏移地址。

    14310

    React的useLayoutEffect和useEffect执行时机有什么不同

    注意加粗的字段,React 官方的文档其实把两个 hook 的执行时机说的很清楚,下面我们深入到 react 的执行流程中来理解下问题useEffect 和 useLayoutEffect 的区别?...为什么建议将修改 DOM 的操作里放到 useLayoutEffect 里,而不是 useEffect?...,这个阶段主要调用的函数是 commitWork,commitWork 函数会针对不同的 fiber 节点调用不同的 DOM 的修改方法,比如文本节点和元素节点的修改方法是不一样的。...为什么建议将修改 DOM 的操作里放到 useLayoutEffect 里,而不是 useEffect?...由于内存中的 DOM 已经被修改,通过 useLayoutEffect 可以拿到最新的 DOM 节点,并且在此时对 DOM 进行样式上的修改,假设修改了元素的 height,这些修改会在步骤 11 和

    1.9K30

    React的useLayoutEffect和useEffect执行时机有什么不同

    注意加粗的字段,React 官方的文档其实把两个 hook 的执行时机说的很清楚,下面我们深入到 react 的执行流程中来理解下问题useEffect 和 useLayoutEffect 的区别?...为什么建议将修改 DOM 的操作里放到 useLayoutEffect 里,而不是 useEffect?...,这个阶段主要调用的函数是 commitWork,commitWork 函数会针对不同的 fiber 节点调用不同的 DOM 的修改方法,比如文本节点和元素节点的修改方法是不一样的。...为什么建议将修改 DOM 的操作里放到 useLayoutEffect 里,而不是 useEffect?...由于内存中的 DOM 已经被修改,通过 useLayoutEffect 可以拿到最新的 DOM 节点,并且在此时对 DOM 进行样式上的修改,假设修改了元素的 height,这些修改会在步骤 11 和

    1.8K40
    领券