| 此组指令有:双精度左移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
| |