第三章、汇编2

算术逻辑操作

加载有效地址

leaq 这个指令是烦人的,leaq (address), %rax, 首先(address)表示获取某个地址的值,而leaq(load effective address)又是去取得一个值的地址(&value),那么取得的结果就是address, 所以本质就是把address放到寄存器中。这个好处是可以利用一些简单的加法和乘法,减少指令个数。可以做一下书里的练习题。

一元和二元操作

  • inc
  • dec
  • neg
  • not

移位操作

特殊算术操作

控制

条件码

访问条件码

跳转指令

这里有个疑惑记录一下,140页书里有一行代码:7f f8 // jg 5

跳转指令相对位置编码很好理解,但是书里把0xf8翻译成-8我就很不理解,

问:为啥反汇编的话这么确定就把这个二进制当作补码处理来翻译?

查阅资料有人说汇编后的二进制数都是补码,这个姑且先这么看,权威资料没查到。

问:如果0xf8被翻译成-8,那么248这个数值二进制咋表示?

chat-gpt解释如下:其实jmp分为相对短跳转(short jump)和相对长跳转(near jump),二者的汇编虽然都是用jmp这三个字母,但是汇编器会根据输入立即数的大小翻译成不同的二进制, 指令分别被翻译EB(短跳转) 和 E9(长跳转), 二者立即数范围分别是1字节(-128~+127)和4字节 (-2,147,483,648 ~ +2,147,483,647)。举个例子:

  1. jmp $4096 最后会被汇编器翻译成:
    E9 00 00 10 00(小端机器)
  2. jmp $-8 最后会被汇编器翻译成:
    EB f8
  3. jmp $248 最后会被汇编器翻译成:
    E9 f8 00 00 00 (小端机器)

跳转指令的编码

用条件控制来实现条件分支

用条件传送来实现条件分支

switch语句

相关推荐
liulilittle5 小时前
C++ i386/AMD64平台汇编指令对齐长度获取实现
c语言·开发语言·汇编·c++
工业互联网专业5 小时前
汇编与接口技术:8259中断实验
汇编·单片机·嵌入式硬件·8259中断实验
small_wh1te_coder19 小时前
硬件嵌入式学习路线大总结(一):C语言与linux。内功心法——从入门到精通,彻底打通你的任督二脉!
linux·c语言·汇编·嵌入式硬件·算法·c
Ronin-Lotus13 天前
微处理器原理与应用篇---ARM常见汇编指令
汇编·arm开发·微处理原理与应用
永夜的黎明16 天前
【二进制安全作业】250616课上作业1-栈溢出漏洞利用
c语言·汇编·安全
Geometry Fu18 天前
物联网控制技术 知识点总结 第三章 汇编语言 第四章 C51语言
汇编·物联网·51单片机
半桔18 天前
【Linux手册】进程的状态:从创建到消亡的“生命百态”
linux·运维·服务器·汇编·深度学习·面试
一条叫做nemo的鱼21 天前
从汇编的角度揭开C++ this指针的神秘面纱(下)
java·汇编·c++·函数调用·参数传递
一条叫做nemo的鱼22 天前
从汇编的角度揭开C++ this指针的神秘面纱(上)
汇编·c++·算法·函数调用·this指针·参数传递
qwertyuiop_i24 天前
汇编(函数调用)
汇编·windows·函数调用