此组指令有:双精度左移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  |                                                             
  
学习和理解双精度移位指令的控件。