汇编指令学习之移位操作

汇编指令中的移位操作分为算术移位和逻辑移位

一般在进行左移操作的时候,算术移位和逻辑移位的处理过程都比较简单:移除左边的最高位,最低位补零

但是在进行右移操作的时候,算术移位移除右边的数字然后左边的最高位进行符号扩展,不过逻辑移位就是补零,则个需要注意一点。

对于需要进行左移和右移的操作,一般都是需要指定移动位数M,如果M=1则可以直接以立即数给出,如果移位超过1则需要把移位放在CL中。

 

移位操作主要分为如下几个指令:

SAL OPRD,M 算术左移

SHL OPRD,M 逻辑左移

SAR OPRD,M 算术右移

SHR OPRD,M 逻辑右移

循环移位没有符号位的扩展等性质

ROL OPRD,M 循环左移<如果操作数为Nbit位,则移动N次后可以还原>

ROR OPRD,M 循环右移

RCL OPRD,M 带进位的循环左移<CF作为循环移动的一部分,需要移动N+1次才可以复位>

RCR OPRD,M 带进位的循环右移

 

一般移位操作都是和逻辑运算结合进行操作数的结合与分解运算

右移操作一般是把最高位移动到CF中

带进位的循环移位操作也是对CF进行了操作,对其他标志位的影响根据相关性质来决定。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
汇编语言移位指令可以用来实现乘法。具体来说,可以使用左移位指令(SHL或者SAL)或者右移位指令(SHR或者SAR)来实现。下面是一种实现乘法的方法: 假设我们要计算a*b,其中a和b是两个8位的整数,那么可以使用以下汇编代码实现: ``` mov al, a ;将a赋值给AL寄存器 mov bl, b ;将b赋值给BL寄存器 xor ah, ah ;清空AH寄存器 mul bl ;将AL和BL寄存器中的数相乘,结果保存在AX寄存器中 ``` 在这个例子中,我们首先将a和b分别存储在AL和BL寄存器中,然后将AH寄存器清空,接着使用mul指令将AL和BL中的数相乘,并将结果保存在AX寄存器中。这里的关键是mul指令,它会将AL和BL中的数相乘,并将结果保存在AX寄存器中。因为AL和BL都是8位的寄存器,所以乘积最多只有16位,可以放入AX寄存器中。 如果要计算更大的整数,可以使用更大的寄存器来保存结果。例如,如果要计算32位整数a*b,可以使用EAX寄存器来保存结果,代码如下: ``` mov eax, a ;将a赋值给EAX寄存器 imul ebx, b ;将b乘以EAX寄存器中的数,并将结果保存在EAX寄存器中 ``` 在这个例子中,我们使用了imul指令来实现乘法。imul指令可以用来计算有符号整数和无符号整数的乘积。它会将两个操作数相乘,并将结果保存在第一个操作数中(也就是第一个操作数必须是一个可写的寄存器)。因为EAX寄存器是32位的,所以可以用来保存32位整数的乘积。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值