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位的最高位上,因此实现了总体右移。