汇编累加到100示例程序移位的理解

include io32.inc
       .data
     num dword 100
     sum qword ?
       .code
start: 
        mov eax,num
        add eax,1
        imul num
        shr edx,1        
        rcr eax,1
        mov dword ptr sum,eax      
        mov dword ptr sum+4,edx
        mov eax, dword ptr sum
        call dispuid
        exit 0
        end start


为了计算(1+100)*100/2中的除以二,书上给出了移位的方式,由于之前那部分看得不仔细,结果就看不懂了,特此写下博客引以为戒,众多周知向右移移位相当于除以二,而汇编规定被除数位数应为除数的2倍,因为这个是32位汇编因此64位数据分别存放于edx(高32位)和eax(低32位),想要它们同时向右移1位,代码中用了shr和rcr,shr使得edx在移位的同时最高位补0,最低位进CF,而RCR则是带进位循环,最低位进CF,CF进最高位。也就是说高32位的最低位刚好补在低32位的最高位上,因此实现了总体右移。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值