正数的左移和右移
以3为例
3的二进制为
00000011
右移2位的时候将最右的11去掉左边补00结果为:00000000 --- >十进是中的0
左移2位的时候将最左的00去掉右边补00结果为:00001100 ----->十进是中的12
对于-3来说,负数的都是以补码的形式存在于计算器中
补码 = 反码+1
-3的二进制为
100000011
取反的补码为(符号为不变)
111111100
再加1,为补码11111101
右移2位的时候将最右的01去掉左边补11结果为:11111111 ---> 为补码,要求原码
还需要-1 :11111110 ,再取反(符号位不动) :10000001:------>十进制中的-1,所以-3的右移2位为十进制中的-1
左移2位的时候将最左边11去掉右边补00结果为:11110100 ----> 为补码,要求原码
还需要-1:11110011,再取反(符号位不动):10001100:----->十进制中的-12,所以-3的左移2位为十进制中的-12
1、SHLD AX, BX, 1 (AX)=1234H,(BX)=8765H (AX)=2469H
(AX)=1234H=0001 0010 0011 0100,左移一位,也就是0010 0100 0110 100X,最后的X需要由操作数二的高位,也就是8H,也就是1000中的左边第一个1填充,从而变成0010 0100 0110 1001,也就是2469H
2、HLD AX, BX, 3 (AX)=1234H,(BX)=8765H (AX)=91A4H
(AX)=1234H=0001 0010 0011 0100,左移三位,也就是1001 0001 1010 0XXX,最后的三个X需要由操作数二的高位,也就是8H,也就是1000中的前三位,即100填充,从而变成1001 0001 1010 0100,也就是91A4H
3、SHRD AX, BX, 2 (AX)=1234H,(BX)=8765H (AX)=448DH
(AX)=1234H=0001 0010 0011 0100,右移两位,也就是XX00 0100 1000 1101,最开始的两个X需要由操作数二的低位,也就是5H,也就是0101中的最右边两位01填充,从而变成0100 0100 1000 1101,也就是448DH
4、SHRD AX, BX, 4 (AX)=1234H,(BX)=8765H (AX)=5123H
(AX)=1234H=0001 0010 0011 0100,右移四位,也就是XXXX 0001 0010 0011,最开始的四个X需要由操作数二的低位,也就是5H,也就是0101中的这四位填充,从而变成0101 0001 0010 0011,也就是5123H