求汇编指令集
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了求汇编指令集相关的知识,希望对你有一定的参考价值。
要详解,比如:ja表示无符号大于,jg表示有符号大于。
参考技术A 一、数据传输指令1. 通用数据传送指令.
MOV 传送字或字节.
MOVSX 先符号扩展,再传送.
MOVZX 先零扩展,再传送.
PUSH 把字压入堆栈.
POP 把字弹出堆栈.
PUSHA 把AX,CX,DX,BX,SP,BP,SI,DI依次压入堆栈.
POPA 把DI,SI,BP,SP,BX,DX,CX,AX依次弹出堆栈.
PUSHAD 把EAX,ECX,EDX,EBX,ESP,EBP,ESI,EDI依次压入堆栈.
POPAD 把EDI,ESI,EBP,ESP,EBX,EDX,ECX,EAX依次弹出堆栈.
BSWAP 交换32位寄存器里字节的顺序
XCHG 交换字或字节.( 至少有一个操作数为寄存器,段寄存器不可作为操作数)
CMPXCHG 比较并交换操作数.( 第二个操作数必须为累加器AL/AX/EAX )
XADD 先交换再累加.( 结果在第一个操作数里 )
XLAT 字节查表转换.── BX 指向一张 256 字节的表的起点, AL 为表的索引值 (0-255,即0-FFH); 返回 AL 为查表结果. ( [BX+AL]->AL )
2. 输入输出端口传送指令.
IN I/O端口输入. ( 语法: IN 累加器, 端口号│DX )
OUT I/O端口输出. ( 语法: OUT 端口号│DX,累加器 )输入输出端口由立即方式指定时, 其范围是 0-255; 由寄存器 DX 指定时,其范围是 0-65535.
3. 目的地址传送指令.
LEA 装入有效地址.例: LEA DX,string ;把偏移地址存到DX.
LDS 传送目标指针,把指针内容装入DS.例: LDS SI,string ;把段地址:偏移地址存到DS:SI.
LES 传送目标指针,把指针内容装入ES.例: LES DI,string ;把段地址:偏移地址存到ES:DI.
LFS 传送目标指针,把指针内容装入FS.例: LFS DI,string ;把段地址:偏移地址存到FS:DI.
LGS 传送目标指针,把指针内容装入GS.例: LGS DI,string ;把段地址:偏移地址存到GS:DI.
LSS 传送目标指针,把指针内容装入SS.例: LSS DI,string ;把段地址:偏移地址存到SS:DI.
4. 标志传送指令.
LAHF 标志寄存器传送,把标志装入AH.
SAHF 标志寄存器传送,把AH内容装入标志寄存器.
PUSHF 标志入栈.
POPF 标志出栈.
PUSHD 32位标志入栈.
POPD 32位标志出栈.
二、算术运算指令
───────────────────────────────────────
ADD 加法.
ADC 带进位加法.
INC 加 1.
AAA 加法的ASCII码调整.
DAA 加法的十进制调整.
SUB 减法.
SBB 带借位减法.
DEC 减 1.
NEG 求反(以 0 减之).
CMP 比较.(两操作数作减法,仅修改标志位,不回送结果).
AAS 减法的ASCII码调整.
DAS 减法的十进制调整.
MUL 无符号乘法.
IMUL 整数乘法.以上两条,结果回送AH和AL(字节运算),或DX和AX(字运算),
AAM 乘法的ASCII码调整.
DIV 无符号除法.
IDIV 整数除法.以上两条,结果回送:商回送AL,余数回送AH, (字节运算);或 商回送AX,余数回送DX, (字运算).
AAD 除法的ASCII码调整.
CBW 字节转换为字. (把AL中字节的符号扩展到AH中去)
CWD 字转换为双字. (把AX中的字的符号扩展到DX中去)
CWDE 字转换为双字. (把AX中的字符号扩展到EAX中去)
CDQ 双字扩展. (把EAX中的字的符号扩展到EDX中去)
三、逻辑运算指令
AND 与运算.
or 或运算.
XOR 异或运算.
NOT 取反.
TEST 测试.(两操作数作与运算,仅修改标志位,不回送结果).
SHL 逻辑左移.
SAL 算术左移.(=SHL)
SHR 逻辑右移.
SAR 算术右移.(=SHR)
ROL 循环左移.
ROR 循环右移.
RCL 通过进位的循环左移.
RCR 通过进位的循环右移.
以上八种移位指令,其移位次数可达255次.
移位一次时, 可直接用操作码. 如 SHL AX,1.
移位>1次时, 则由寄存器CL给出移位次数.
如 MOV CL,04
SHL AX,CL
四、串指令
DS:SI 源串段寄存器 :源串变址.
ES:DI 目标串段寄存器:目标串变址.
CX 重复次数计数器.
AL/AX 扫描值.
D标志 0表示重复操作中SI和DI应自动增量; 1表示应自动减量.
Z标志 用来控制扫描或比较操作的结束.
MOVS 串传送.( MOVSB 传送字符. MOVSW 传送字. MOVSD 传送双字. )
CMPS 串比较.( CMPSB 比较字符. CMPSW 比较字. )
SCAS 串扫描.把AL或AX的内容与目标串作比较,比较结果反映在标志位.
LODS 装入串.把源串中的元素(字或字节)逐一装入AL或AX中.( LODSB 传送字符. LODSW 传送字. LODSD 传送双字. )
STOS 保存串.是LODS的逆过程.
REP 当CX/ECX<>0时重复.
REPE/REPZ 当ZF=1或比较结果相等,且CX/ECX<>0时重复.
REPNE/REPNZ 当ZF=0或比较结果不相等,且CX/ECX<>0时重复.
REPC 当CF=1且CX/ECX<>0时重复.
REPNC 当CF=0且CX/ECX<>0时重复.
五、程序转移指令
1。无条件转移指令 (长转移)
JMP 无条件转移指令
CALL 过程调用
RET/RETF 过程返回.
2。条件转移指令 (短转移,-128到+127的距离内)
( 当且仅当(SF XOR OF)=1时,OP1<OP2 )
JA/JNBE 不小于或不等于时转移.
JAE/JNB 大于或等于转移.
JB/JNAE 小于转移.
JBE/JNA 小于或等于转移.
以上四条,测试无符号整数运算的结果(标志C和Z).
JG/JNLE 大于转移.
JGE/JNL 大于或等于转移.
JL/JNGE 小于转移.
JLE/JNG 小于或等于转移.
以上四条,测试带符号整数运算的结果(标志S,O和Z).
JE/JZ 等于转移.
JNE/JNZ 不等于时转移.
JC 有进位时转移.
JNC 无进位时转移.
JNO 不溢出时转移.
JNP/JPO 奇偶性为奇数时转移.
JNS 符号位为 "0" 时转移.
JO 溢出转移.
JP/JPE 奇偶性为偶数时转移.
JS 符号位为 "1" 时转移.
3。循环控制指令(短转移)
LOOP CX不为零时循环.
LOOPE/LOOPZ CX不为零且标志Z=1时循环.
LOOPNE/LOOPNZ CX不为零且标志Z=0时循环.
JCXZ CX为零时转移.
JECXZ ECX为零时转移.
4。中断指令
INT 中断指令
INTO 溢出中断
IRET 中断返回
5。处理器控制指令
HLT 处理器暂停, 直到出现中断或复位信号才继续.
WAIT 当芯片引线TEST为高电平时使CPU进入等待状态.
ESC 转换到外处理器.
LOCK 封锁总线.
NOP 空操作.
STC 置进位标志位.
CLC 清进位标志位.
CMC 进位标志取反.
STD 置方向标志位.
CLD 清方向标志位.
STI 置中断允许位.
CLI 清中断允许位.
六、伪指令
DW 定义字(2字节).
PROC 定义过程. 例子:name proc var1,var2,var3
ENDP 过程结束.例子:name endp
SEGMENT 定义段.例子 name segment
ASSUME 建立段寄存器寻址. 例子:assume cs:codes,ds:datas,ss:stacks
ENDS 段结束.name ends
END 程序结束(同时指出指令入口,即程序执行的第一条指令).end start
七、处理机控制指令:
标志处理指令 CLC(进位位置0指令)
CMC(进位位求反指令)
STC(进位位置为1指令)
CLD(方向标志置1指令)
STD(方向标志位置1指令)
CLI(中断标志置0指令)
STI(中断标志置1指令)
NOP(无操作)
HLT(停机)
WAIT(等待)
ESC(换码)
LOCK(封锁)+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++浮点协处理器+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++浮点指令
对下面的指令先做一些说明:
st(i):代表浮点寄存器,所说的出栈、入栈操作都是对st(i)的影响
src,dst,dest,op等都是指指令的操作数,src表示源操作数,dst/dest表示目的操作数
mem8,mem16,mem32,mem64,mem80等表示是内存操作数,后面的数值表示该操作数的内存位数(8位为一字节)
x <- y 表示将y的值放入x,例st(0) <- st(0) - st(1)表示将st(0)-st(1)的值放入浮点寄存器st(0)
1. 数据传递和对常量的操作指令
指令格式
指令含义
执行的操作
FLD src
装入实数到st(0)
st(0) <- src (mem32/mem64/mem80)
FILD src
装入整数到st(0)
st(0) <- src (mem16/mem32/mem64)
FBLD src
装入BCD数到st(0)
st(0) <- src (mem80)
FLDZ
将0.0装入st(0)
st(0) <- 0.0
FLD1
将1.0装入st(0)
st(0) <- 1.0
FLDPI
将pi装入st(0)
st(0) <- ?(ie, pi)
FLDL2T
将log2(10)装入st(0)
st(0) <- log2(10)
FLDL2E
将log2(e)装入st(0)
st(0) <- log2(e)
FLDLG2
将log10(2)装入st(0)
st(0) <- log10(2)
FLDLN2
将loge(2)装入st(0)
st(0) <- loge(2)
FST dest
保存实数st(0)到dest
dest <- st(0) (mem32/mem64)
FSTP dest
dest <- st(0) (mem32/mem64/mem80);然后再执行一次出栈操作
FIST dest
将st(0)以整数保存到dest
dest <- st(0) (mem32/mem64)
FISTP dest
dest <- st(0) (mem16/mem32/mem64);然后再执行一次出栈操作
FBST dest
将st(0)以BCD保存到dest
dest <- st(0) (mem80)
FBSTP dest
dest<- st(0) (mem80);然后再执行一次出栈操作
2.比较指令
指令格式
指令含义
执行的操作
FCOM
实数比较
将标志位设置为 st(0) - st(1) 的结果标志位
FCOM op
实数比较
将标志位设置为 st(0) - op (mem32/mem64)的结果标志位
FICOM op
和整数比较
将Flags值设置为st(0)-op 的结果op (mem16/mem32)
FICOMP op
和整数比较
将st(0)和op比较 op(mem16/mem32)后;再执行一次出栈操作
FTST
零检测
将st(0)和0.0比较
FUCOM st(i)
比较st(0) 和st(i) [486]
FUCOMP st(i)
比较st(0) 和st(i),并且执行一次出栈操作
FUCOMPP st(i)
比较st(0) 和st(i),并且执行两次出栈操作
FXAM
Examine: Eyeball st(0) (set condition codes)
3.运算指令
指令格式
指令含义
执行的操作
加法
FADD
加实数
st(0) <-st(0) + st(1)
FADD src
st(0) <-st(0) + src (mem32/mem64)
FADD st(i),st
st(i) <- st(i) + st(0)
FADDP st(i),st
st(i) <- st(i) + st(0);然后执行一次出栈操作
FIADD src
加上一个整数
st(0) <-st(0) + src (mem16/mem32)
减法
FSUB
减去一个实数
st(0) <- st(0) - st(1)
FSUB src
st(0) <-st(0) - src (reg/mem)
FSUB st(i),st
st(i) <-st(i) - st(0)
FSUBP st(i),st
st(i) <-st(i) - st(0),然后执行一次出栈操作
FSUBR st(i),st
用一个实数来减
st(0) <- st(i) - st(0)
FSUBRP st(i),st
st(0) <- st(i) - st(0),然后执行一次出栈操作
FISUB src
减去一个整数
st(0) <- st(0) - src (mem16/mem32)
FISUBR src
用一个整数来减
st(0) <- src - st(0) (mem16/mem32)
乘法
FMUL
乘上一个实数
st(0) <- st(0) * st(1)
FMUL st(i)
st(0) <- st(0) * st(i)
FMUL st(i),st
st(i) <- st(0) * st(i)
FMULP st(i),st
st(i) <- st(0) * st(i),然后执行一次出栈操作
FIMUL src
乘上一个整数
st(0) <- st(0) * src (mem16/mem32)
除法
FDIV
除以一个实数
st(0) <-st(0) /st(1)
FDIV st(i)
st(0) <- st(0) /t(i)
FDIV st(i),st
st(i) <-st(0) /st(i)
FDIVP st(i),st
st(i) <-st(0) /st(i),然后执行一次出栈操作
FIDIV src
除以一个整数
st(0) <- st(0) /src (mem16/mem32)
FDIVR st(i),st
用实数除
st(0) <- st(i) /st(0)
FDIVRP st(i),st
FDIVRP st(i),st
FIDIVR src
用整数除
st(0) <- src /st(0) (mem16/mem32)
FSQRT
平方根
st(0) <- sqrt st(0)
FSCALE
2的st(0)次方
st(0) <- 2 ^ st(0)
FXTRACT
Extract exponent:
st(0) <-exponent of st(0); and gets pushed
st(0) <-significand of st(0)
FPREM
取余数
st(0) <-st(0) MOD st(1)
FPREM1
取余数(IEEE),同FPREM,但是使用IEEE标准[486]
FRNDINT
取整(四舍五入)
st(0) <- INT( st(0) ); depends on RC flag
FABS
求绝对值
st(0) <- ABS( st(0) ); removes sign
FCHS
改变符号位(求负数)
st(0) <-st(0)
F2XM1
计算(2 ^ x)-1
st(0) <- (2 ^ st(0)) - 1
FYL2X
计算Y * log2(X)
st(0)为Y;st(1)为X;将st(0)和st(1)变为st(0) * log2( st(1) )的值
FCOS
余弦函数Cos
st(0) <- COS( st(0) )
FPTAN
正切函数tan
st(0) <- TAN( st(0) )
FPATAN
反正切函数arctan
st(0) <- ATAN( st(0) )
FSIN
正弦函数sin
st(0) <- SIN( st(0) )
FSINCOS
sincos函数
st(0) <-SIN( st(0) ),并且压入st(1)
st(0) <- COS( st(0) )
FYL2XP1
计算Y * log2(X+1)
st(0)为Y; st(1)为X; 将st(0)和st(1)变为st(0) * log2( st(1)+1 )的值
处理器控制指令
FINIT
初始化FPU
FSTSW AX
保存状态字的值到AX
AX<- MSW
FSTSW dest
保存状态字的值到dest
dest<-MSW (mem16)
FLDCW src
从src装入FPU的控制字
FPU CW <-src (mem16
FSTCW dest
将FPU的控制字保存到dest
dest<- FPU CW
FCLEX
清除异常
FSTENV dest
保存环境到内存地址dest处 保存状态字、控制字、标志字和异常指针的值
FLDENV src
从内存地址src处装入保存的环境
FSAVE dest
保存FPU的状态到dest处 94字节
FRSTOR src
从src处装入由FSAVE保存的FPU状态
FINCSTP
增加FPU的栈指针值
st(6) <-st(5); st(5) <-st(4),...,st(0) <-?
FDECSTP
减少FPU的栈指针值
st(0) <-st(1); st(1) <-st(2),...,st(7) <-?
FFREE st(i)
标志寄存器st(i)未被使用
FNOP
空操作,等同CPU的nop
st(0) <-st(0)
WAIT/FWAIT
同步FPU与CPU:停止CPU的运行,直到FPU完成当前操作码
FXCH
交换指令,交换st(0)和st(1)的值
st(0) <-st(1)
st(1) <- st(0)+++++++++++++++手痛!!经我检查的!+++++++++++++++ 参考技术B ,去甲壳虫技术论坛看看吧。 那里很全面的。 ···
汇编程序基本指令集
指令概述
指令
指令是CPU操作的基本单位,每条指令执行一个特定的操作。可以理解为:指令通知CPU执行某种操作的“命令”。CPU全部指令的集合,称为指令集
指令分类
- 机器指令:二进制格式编码的序列(一串0,1代码书写)。
注意:硬件只能识别,存储,运行机器指令
- 符号指令:用字符串形式的序列(包含字符串形式的操作码以及操作数助记符)
汇编语言基本指令集
总说明(所有的指令都要遵守的)
- 对于双操作数指令(如:MOV,ADD,CMP…)
- 源,目操作数不可同为内存操作数
- 源,目操作数属性一致(长度相同)
- 当源操作数为立即数,目标操作数为非变量名直接寻址的内存操作数,则目标操作数必须用
PTR
说明类型
- 对于单操作指令(如:INC,DEC…)
- 若操作数为非变量名直接寻址的内存操作数,则必须使用PTR说明类型
常用伪指令
数据定义伪指令
DB
:字节定义伪指令
功能:将数据存放到计算机中的内存单元时,负数按照补码存放,单引号中的字符翻译成ASCII码
2. DW
:字定义伪指令
功能:通知汇编程序把DW后跟的双字节数,依次存入从变量名开始的单元,每一个数,占两个字节,存放时满足小端法规则,即:低字节->低地址单元,高字节->高地址单元。
3. DD
:双字定义伪指令
变量名 DD 一串用逗号间隔的4字节数
功能:将数据存放到计算机中的内存单元时,负数按照补码存放,单引号中的字符翻译成ASCII码
符号定义伪指令
EQU
:等值伪指令
NUM EQU 33
MOV AL,NUM ;该指令与下条指令等价
MOV AL,33
=
:等号伪指令
NUM = 33
功能:定义符号常数NUM的值为33
3.EQU和=区别
- 用EQU定义的符号常数,其值在后句语句中不能更改
- 用=定义的符号常数,其值在后继语句中可以重新定义
通用传送类指令
数据传送指令
(1) 数据传送指令:
MOV 目,源
功能:把源操作数赋值(传送)给目的操作数,源操作数不变
说明: 不能向段寄存器中写入立即数
CS不能做目标寄存器
注意:不能用一条指令实现以下传送:
1. 存储单元之间的传送
2. 立即数至段寄存器的传送(中间需要使用一个通用寄存器中转)
3. 段寄存器之间的传送
符号扩展/零扩展传送指令
(2) 符号扩展/零扩展传送指令
MOVSX 目标寄存器,源操作数
MOVZX 目标寄存器,源操作数
功能:把源操作数赋值(传送)给目的操作数,源操作数不变
说明: 1.源操作数不变
2.源操作数字长要小于或等于目标寄存器字长
3. MOVSX源操作数符号位向高位扩展,再送给目标
4. MOVZX源操作数高位补零,再送给目标
有效地址传送指令
(3) 有效地址传送指令
LEA 目标寄存器,源操作数
功能:计算内存单元的有效地址(不是其中的操作数)->目标
说明:有效地址就是偏移地址,LEA指令等效于OFFSET运算符
交换传送指令
(4) 交换传送指令
XCHG 第一操作数,第二操作数
功能:完成两个操作数互换
说明: 1. 段寄存器,立即数不能参加互换
2. 2个内存操作数不能互换,源,目的类型一致
堆栈操作类指令
堆栈的基本概念
堆栈————计算机中的堆栈是人为设置的一片连续内存区,用来存放数据,所存数据按先进后出规律存取
栈顶:栈区的低地址
栈底:栈区的高地址
- 堆栈寄存器SS:存放堆栈段段基址
- 堆栈指针(SP):存放栈顶单元的偏移地址
堆栈指针SP的初值决定了堆栈的大小,SP始终指向栈顶的顶部,及始终指向最后压入堆栈的信息所在的单元
数据进出栈
入栈PUSH
PUSH src;(先移后入)
一个字进栈,系统自动完成两步操作:SP←SP-2,(SP)←操作数;
一个双字进栈,系统自动完成两步操作:ESP←ESP-4,(ESP)←操作数。
出栈POP
POP dst;(先出后移)
弹出一个字,系统自动完成两步操作:操作数←(SP),SP←SP+2;
弹出一个双字,系统自动完成两步操作:操作数←(ESP),ESP←ESP+4。
注意:堆栈操作指令中的操作数类型必须是字操作数,即16位操作数
算数运算类指令
- 二进制加法
ADD
:不带进位加法指令
ADD 目标操作数(dst),源操作数(src) ;dst <- dst+src
功能:将目的操作数与源操作数相加,并将结果送给目的操作数
ADC
:带进位加法指令
ADC 目标操作数(dst),源操作数(src) ;dst <- dst+src+CF
功能:将目的操作数与源操作数相加,再加上进位标志CF的内容,然后将结果送给目的操作数
INC
:加一指令
INC 目标操作数(dst) ;dst <- dst+1
功能:将目的操作数加一,并将结果送回目的操作数。
- 二进制减法
1.SUB
:不带借位减法指令
SUB 目标操作数(dst),源操作数(src) ;dst <- dst-src;
功能:将目的操作数减源操作数,结果送回目的操作数。
2.SBB
:带借位减法指令
SBB 目标操作数(dst),源操作数(src) ;dst <- dst-src-CF;
功能:将目的操作数减源操作数,然后再减进位标志CF,并将结果送回目的操作数。
DEC
:减一指令
DEC 目标操作数(dst) ;dst <- dst-1
功能:将目的操作数减一,结果送回目的操作数。
- 求补指令
NEG
:求补指令
NEG 目标操作数(dst) ; dst <- 0-dst
功能:用0减去目的操作数,结果送回原来的目的操作数。
- 比较指令
CMP
:比较指令
CMP 目标操作数(dst),源操作数(src) ;dst-src
功能:将目的操作数减源操作数,但结果不送回目的操作数。
- 乘法指令
MUL
:无符号数乘法指令
MUL src ;(AX)<-(src)*(AL)
功能:将源操作数与默认的目的操作数(AX或AL)相乘,结果保存在AX或DX,AX中。
IMUL
:带符号数乘法指令
IMUL src ;
功能:将源操作数与默认的目的操作数(AX或AL)相乘,结果保存在AX或DX,AX中。
说明:运算结果只影响状态标志CF,OF;
- 除法指令
DIV
:无符号数除法指令
DIV src ;(AL)<-(AX)*(src) (商) (AH) <- 余数
功能:将两个无符号数做除法运算,商和余数分别保存在指定位置。
IDIV
:带符号数除法指令
IDIV src
功能:将两个带符号数做除法运算,商和余数分别保存在指定位置。
说明:当被除数位不够时,需要进行扩展。
- 字节扩展指令
CBW
功能:把AL中的带符号数扩展为16位字长(符号位扩展到AH中)。
- 字扩展指令
CWD
功能:将AX中的符号位扩展到DX中
转移类指令
- 按照转移条件分:无条件转移和有条件转移
有符号条件转移
循环控制转移
- 按照转移范围分:段内转移和段间转移
- 按照获取转移地址的方法分:直接转移和间接转移
调用类指令
子程序调用与返回指令
CALL <调用地址>
RET ;返回断点
子程序
:能完成一定功能的相对独立的程序段
调用
:调用子程序,即无条件转到子程序的第一条指令
返回
:返回断点,即返回到CALL
的后继指令
段内调用CALL指令
段内直接调用
:主程序和子程序待在同一代码段中
CALL 过程名
段内间接调用
CALL 寄存器操作数
CALL 内存操作数
子程序(汇编语言)的过程定义语句
过程名 PROC 属性
子程序实体
RET
过程名 ENDP
过程名
:子程序名,以字母开头,经汇编之后,过程名就是子程序的第一条指令
PROC/ENDP
:是子程序的定界语句
属性
: NEAR(或缺省)代表近过程,即该子程序和调用它的那条指令在同一个代码段。
FAR代表远过程,即该子程序和调用它的那条指令不在同一个代码段。
RET
:RET子程序返回指令
逻辑运算类指令
NOT
:取反
NOT 目的操作数(dst)
功能:实现操作数的按位取反运算,把取反的结果送给目标操作数
说明:NOT用于使所有位取反
AND
:与指令
AND 目的操作数(dst),源操作数(src)
功能:实现两个操作数的按位与运算,将两个操作数与之后的结果送给目标操作数
说明:AND通常用于使某些位置0,其他位不变的情况
OR
:或运算
OR 目的操作数(dst),源操作数(src)
功能:实现操作数的按位或运算,把或的结果送给目标操作数
说明:OR通常用于将某些位置1
XOR
:异或运算
XOR 目的操作数(dst),源操作数(src)
功能:实现操作数的按位异或运算,把异或的结果送给目标操作数
说明:XOR通常用于将某些位取反,某些位保持不变
TEST
:测试
TEST 目的操作数(dst),源操作数(src)
功能:实现两个操作数的按位与运算,结果不保存,只影响标志位
移位指令
开环移位指令
算数左移
SAL 操作数,移位次数
说明:操作数向左移位,最高位被挤入进位位中,用0来补充最低位
算数右移
SAR 操作数,移位次数
说明:操作数向右移位,最低位被挤入进位位中,用原来操作数的最高位来补充最高位
逻辑左移
SHL 操作数,移位次数
说明:操作数向左移位,最高位被挤入进位位中,用0来补充最低位
逻辑右移
SHR 操作数,移位次数
说明:操作数向右移位,最低位被挤入进位位中,用0来补充最高位
闭环移位指令
含进位的循环左移
RCL 操作数,移位次数
说明:操作数向左移位,最高位被挤入进位位中,用原来的进位位来补充最低位
含进位的循环右移
RCR 操作数,移位次数
说明:操作数向右移位,最低位被挤入进位位中,用原来进位位来补充最高位
不含进位的循环左移
ROL 操作数,移位次数
说明:操作数向左移位,最高位被挤入操作数的最低位,同时最高位进入进位位,用操作数的次高位补充最高位
不含进位的循环右移
ROR 操作数,移位次数
说明:操作数向右移位,最低位被挤入操作数的最高位,同时最低位进入进位位,用操作数的次低位补充最低位。
以上是关于求汇编指令集的主要内容,如果未能解决你的问题,请参考以下文章