灯火互联
管理员
管理员
  • 注册日期2011-07-27
  • 发帖数41778
  • QQ
  • 火币41290枚
  • 粉丝1086
  • 关注100
  • 终身成就奖
  • 最爱沙发
  • 忠实会员
  • 灌水天才奖
  • 贴图大师奖
  • 原创先锋奖
  • 特殊贡献奖
  • 宣传大使奖
  • 优秀斑竹奖
  • 社区明星
阅读:3077回复:0

双精度移位指令

楼主#
更多 发布于:2012-09-10 18:57

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

喜欢0 评分0
游客

返回顶部