5.2.5 双精度移位指令
优质
小牛编辑
174浏览
2023-12-01
3、双精度移位指令
此组指令有:双精度左移SHLD(Shift Left Double)和双精度右移SHRD(Shift Right Double)。它们都是具有三个操作数的指令,其指令的格式如下:
SHLD/SHRD Reg/Mem, Reg, CL/Imm;80386+
其中:第一操作数是一个16位/32位的寄存器或存储单元;第二操作数(与前者具有相同位数)一定是寄存器;第三操作数是移动的位数,它可由CL或一个立即数来确定。
在执行SHLD指令时,第一操作数向左移n位,其“空出”的低位由第二操作数的高n位来填补,但第二操作数自己不移动、不改变。
在执行SHRD指令时,第一操作数向右移n位,其“空出”的高位由第二操作数的低n位来填补,但第二操作数自己也不移动、不改变。
SHLD和SHRD指令的移位功能示意图如图5.8所示。
受影响的标志位:CF、OF、PF、SF和ZF(AF无定义)
(a)、SHLD | (b)、SHRD |
图5.8 双精度移位指令操作示意图
下面是几个双精度移位的例子及其执行结果。
双精度移位指令 | 指令操作数的初值 | 指令执行后的结果 |
SHLD AX, BX, 1 | (AX)=1234H,(BX)=8765H | (AX)=2469H |
SHLD AX, BX, 3 | (AX)=1234H,(BX)=8765H | (AX)=91A4H |
SHRD AX, BX, 2 | (AX)=1234H,(BX)=8765H | (AX)=448DH |
SHRD AX, BX, 4 | (AX)=1234H,(BX)=8765H | (AX)=5123H |
学习和理解双精度移位指令的控件。