汇编中一些简单指令(持续更新)
- jne:jump if not equal
- je:jump if equal
- ja:jump above
- jbe:jump below equal (al小于bl)
(JGB,JLB是比较带符号数的转移指令 - jge:jump if greater equal
- jle:jump if less equal(或者是:jng jump not greater)
- jmp: **JMP是汇编语言中的无条件跳转指令。**无条件跳转指令可转到内存中任何程序段。在根本上,将cs,ip寄存器所指向的内存当做代码,指令转移就是修改cs,ip寄存器的指向,汇编中提供了一种修改它们的指令——jmp。
jmp指令可以修改IP或cs和IP的值来实现指令转移,指令格式为:”jmp 标号“将指令转移到标号处.
很不懂:
SF OF ZF
**
👇与test汇编指令有关
- Test命令将两个操作数进行逻辑与运算,并根据运算结果设置相关的标志位。但是,Test命令的两个操作数不会被改变。运算结果在设置过相关标记位后会被丢弃。
(功能即为测试,两操作数作与运算,仅修改标志位,不回送结果) - Test对两个参数(目标,源)执行AND逻辑操作,并根据结果设置标志寄存器,结果本身不会保存。TEST AX,BX 与 AND AX,BX 命令有相同效果,只是Test指令不改变AX和BX的内容,而AND指令会把结果保存到AX中。
- AND逻辑操作:
https://baike.sogou.com/v64825130.htm?fromTitle=test%EF%BC%88%E6%B1%87%E7%BC%96%E6%8C%87%E4%BB%A4%EF%BC%89 - SF OF AF等
CF(进位标志) =1 算术操作最高位产生了进位或借bai位 =0 最高位无进位或借位 ;
PF(奇偶标志) =1 数据最低8位中1的个数为偶数 =0 数据最低8位中1的个数为奇数;AF(辅助进位标志) =1 D3→D4位产生了进位或借位 =0 D3→D4位无进位或借位;
ZF(零标志) =1 操作结果为0 =0 结果不为0;
SF(符号标志) =1 结果最高位为1 =0 结果最高位为0;
OF(溢出标志) =1 此次运算发生了溢出 =0 无溢出。
**
例:
Test用来测试一个位,例如寄存器:
test eax,100b;b后缀意为二进制
jnz ******;如果eax右数第三个位为1,jnz将会跳转
我是这样想的,jnz跳转的条件是ZF=0,ZF=0意味着ZF(零标志)没被置位,即逻辑与结果为1。
实际例子:
168e: test %esi, %esi
当x<=0(esi)时,跳转到16bb