指令格式:POP Reg/Mem
弹出一个字,系统自动完成两步操作:操作数←(SP) ,SP←SP-2 ;
弹出一个双字,系统自动完成两步操作:操作数←(ESP) ,ESP ←ESP-4。 、POPA(Pop All General Registers) 指令格式:POPA ;80286+
其功能是依次把寄存器DI、SI 、BP、SP、BX、DX、CX和AX等弹出栈。其实, 程序员不用记住它们的具体顺序,只要与指令PUSHA对称使用就可以了。 、POPAD(Pop All 32-bit General Registers) 指令格式:POPAD ;80386+
其功能是依次把寄存器EDI 、ESI、EBP 、ESP 、EBX、EDX、ECX和EAX等弹出 栈,它与PUSHAD 对称使用即可。
7 、转换指令XLAT(Translate Instruction)
转换指令有两个隐含操作数BX和AL。指令格式如 下:
XLAT/XLATB
其功能是把BX 的值作为内存字节数组首地址、下 标为AL的数组元素的值传送给AL。其功能描述的表达 式是:AL←BX[AL],其功能示意图如图5.6所示。 8 、I/O 指令
有关I/O 指令将在第8.1.2节——I/O 指令——中介绍,在此从略。 5.2.2 标志位操作指令
标志位操作指令是一组对标志位置位、复位、保存和恢复等操作的指令。 1 、进位CF操作指令
、清进位指令CLC(Clear Carry Flag):CF←0 、置进位指令STC(Set Carry Flag):CF←1
、进位取反指令CMC(Complement Carry Flag):CF←not CF 2 、方向位DF操作指令
、清方向位指令CLD(Clear Direction Flag) :DF←0 、置方向位指令STD(Set Direction Flag) :DF←1 3 、中断允许位IF 操作指令
、清中断允许位指令CLI(Clear Interrupt Flag):IF ←0
其功能是不允许可屏蔽的外部中断来中断其后程序段的执行。 、置中断允许位指令STI(Set Interrupt Flag):IF ←1
其功能是恢复可屏蔽的外部中断的中断响应功能,通常是与 CLI 成对使用的。 4 、取标志位操作指令
、LAHF(Load AH from Flags):AH←Flags的低8 位 、SAHF(Store AH in Flags):Flags的低8 位←AH 5 、标志位堆栈操作指令
、PUSHF/PUSHFD(Push Flags onto Stack) :把16位/32位标志寄存器进栈; 、POPF/POPFD(Pop Flags off Stack):把16位/32 位标志寄存器出栈; 6 、逻辑操作指令的小结
下面是学习标志位指令的控件,浏览者可以运用此类指令,观看标志寄存器的相应变化。
5.2.3 算术运算指令
算术运算指令是反映CPU 计算能力的一组指令,也是编程时经常使用的一组指令。它 包括:加、减、乘、除及其相关的辅助指令。
该组指令的操作数可以是8 位、16 位和32 位(80386+) 。当存储单元是该类指令的操作数 时,该操作数的寻址方式可以是任意一种存储单元寻址方式。 1 、加法指令
、加法指令ADD(ADD Binary Numbers Instruction) 指令的格式:ADD Reg/Mem, Reg/Mem/Imm 受影响的标志位:AF、CF、OF、PF、SF和ZF
指令的功能是把源操作数的值加到目的操作数中。 、带进位加指令ADC(ADD With Carry Instruction) 指令的格式:ADC Reg/Mem, Reg/Mem/Imm 受影响的标志位:AF、CF、OF、PF、SF和ZF
指令的功能是把源操作数和进位标志位CF的值(0/1) 一起加到目的操作数中。 、加1 指令INC(Increment by 1 Instruction) 指令的格式:INC Reg/Mem
受影响的标志位:AF、OF、PF、SF和ZF,不影响CF 指令的功能是把操作数的值加1 。 、交换加指令XADD(Exchange and Add)
指令的格式:XADD Reg/Mem, Reg ;80486+ 受影响的标志位:AF、CF、OF、PF、SF和ZF
指令的功能是先交换两个操作数的值,再进行算术“加”法操作。
例5.3 已知有二个32位数d1 和d2(用数据类型 DD说明),编写程序片段把d2 的值加到d1 中。
解:32位数d1 和d2 在内存中如下所示。 ? ? ? ? ……
方法1 :用16 位寄存器编写程序 MO V
AX, word ptr d1 ; 由于d1 是双字类型,必须使用强制类型说明符。以下同。 MO V
DX, word ptr d1+2 ;(DX,AX) 构成一个32位数据 AD D
AX, word ptr d2 ; 低字相加 AD
C
DX, word ptr d2+2 ; 高字相加。在低字相加时,有可能会产生“进位” MO V
word ptr d1, AX ; 低字送给d1 的低字 MO V
word ptr d1+2, DX ; 高字送给d1 的高字 方法2 :用32 位寄存器编写程序 MO V
EAX, d1 AD D
EAX, d2 MO V
d1, EAX
从上面两段程序不难看出:用32位寄存器来处理32 位数据显得简单、明了,而16位微机 虽然也能处理32位数据,但做起来就要复杂一些。
下面是学习和掌握加法类指令的控件,可模拟执行 ADD、ADC、INC 、XADD 、CLC 、 STC 和CMC等指令。用鼠标左键单击寄存器列表框中指定的寄存器,则可修改其值。后面 其它控件的有关操作与此相一致,不再说明。
2 、减法指令
、减法指令SUB(Subtract Binary Values Instruction) 指令的格式:SUB Reg/Mem, Reg/Mem/Imm 受影响的标志位:AF、CF、OF、PF、SF和ZF 指令的功能是从目的操作数中减去源操作数。 、带借位减SBB(Subtract with Borrow Instruction) 指令的格式:SBB Reg/Mem, Reg/Mem/Imm 受影响的标志位:AF、CF、OF、PF、SF和ZF
指令的功能是把源操作数和标志位CF的值从目的操作数中一起减去。 、减1 指令DEC(Decrement by 1 Instruction) 指令的格式:DEC Reg/Mem
受影响的标志位:AF、OF、PF、SF和ZF,不影响CF 指令的功能是把操作数的值减去1 。 、求补指令NEG(Negate Instruction) 指令的格式:NEG Reg/Mem
受影响的标志位:AF、CF、OF、PF、SF和ZF
指令的功能:操作数=0-操作数,即改变操作数的正负号。
例5.4 已知有二个32位数d1 和d2 ,编写程序片段从 d1 中减去d2 的值。 解:
方法1 :用16 位寄存器编写程序 MO V
AX, word ptr d1 ; 取低字 MO V
DX, word ptr d1+2 ; 取高字,(DX,AX) 构成一个32位数据 SUB AX, word ptr d2 ;低字相减
SBB DX, word ptr d2+2 ;高字相减。在低字相减时,有可能会产生“借位” MO V
word ptr d1, AX ; 低字送给d1 的低字 MO V
word ptr d1+2, DX ; 高字送给d1 的高字 方法2 :用32 位寄存器编写程序 MO V
EAX, d1 SUB EAX, d2 MO V
d1, EAX
下面是学习和掌握减法类指令的控件,可模拟执行SUB 、SBB 、DEC 、NEG、CLC 、 STC 和CMC等指令。
3 、乘法指令
计算机的乘法指令分为无符号乘法指令和有符号乘法指令,它们的唯一区别就在于:数 据的最高位是作为“数值”参与运算,还是作为“符号位”参与运算。
乘法指令的被乘数都是隐含操作数,乘数在指令中显式地写出来。CPU 会根据乘数是8 位、16位,还是32位操作数,来自动选用被乘数:AL、AX或EAX。
指令的功能是把显式操作数和隐含操作数相乘,并把乘积存入相应的寄存器中。 、无符号数乘法指令MUL(Unsigned Multiply Instruction) 指令的格式:MUL Reg/Mem
受影响的标志位:CF和OF(AF 、PF、SF和ZF无定义)
指令的功能是把显式操作数和隐含操作数(都作为无符号数) 相乘,所得的乘积按表 5.2的对应关系存放。
表5.2 乘法指令中乘数、被乘数和乘积的对应关系 乘数位数隐含的被乘数乘积的存放位置举例 8 位 AL AX MUL BL 16位 AX DX-AX MUL BX
32位 EAX EDX-EAX MUL ECX
、有符号数乘法指令IMUL(Signed Integer Mu ltiply Instruction)
IMU L
Reg/Mem IMU L
Reg, Imm ;80286+ IMU L
Reg, Reg, Imm ;80286+ 指令的格 式: IMU L
Reg, Reg/Mem ;80386+
受影响的标志位:CF和OF(AF 、PF、SF和ZF无定义)
1) 、指令格式1——该指令的功能是把显式操作数和隐含操作数相乘,所得的乘积按表 5.2的对应关系存放。
2) 、指令格式2——其寄存器必须是16位/32 位通用寄存器,其计算方式为: Reg ← Reg × Imm
3) 、指令格式3——其寄存器只能是16位通用寄存器,其计算方式为: Reg1 ← Reg 2
×Imm 或 Reg 1
← Mem×Imm
4) 、指令格式4——其寄存器必须是16位/32 位通用寄存器,其计算方式为: Reg1 ← Reg 1 ×Reg 2
或 Reg 1
← Reg 1
×Mem
在指令格式2~4 中,各操作数的位数要一致。如果乘积超过目标寄存器所能存储的范围, 则系统将置溢出标志OF为1 。
下面是学习和掌握乘法类指令的控件,可模拟执行MUL和IMUL 等指令。
4 、除法指令
除法指令的被除数是隐含操作数,除数在指令中显式地写出来。CPU 会根据除数是8位、 16位,还是32 位,来自动选用被除数 AX、DX-AX,还是EDX-EAX。