单片机里RL A是循环向左移一位(不带进位),为什么相当于把A乘2?
<< : 是左移指令,低位补零。移出去的就消失了。
ROL: 循环左移指令,低位补高位移除的数据。
这是因为计算机的数值在单片机里都是二进制的数值,对它进行左移一位,,相当于每一位都进了一位。例如数值2,用二进制表示为0010,左移一位变成了4,即0100。
例如: 1000,0001 b,
a = 1000,0001 b << 1; 则: a = 0000,0010 b;
a = ROL 1000,0001 b,1; 则: a = 0000,0011 b;
补充:
循环左移ROL(Rotate Left):移出的位不仅要进入CF,而且还要填补空出的位。
带进位的循环左移RCL(Rotate Left Through Carry):用原CF的值填补空出的位,移出的位再进入CF。
扩展资料
算术左移=逻辑左移
说明:算术左移和逻辑左移一样都是右边补0:比如 00101011
算术左移一位:01010110
逻辑左移一位:01010110
(对于二进制的数值来说左移n位等于原来的数值乘以2的n次方。比如00011010十进制是26,左移两位后是01101000转成十进制是104恰好是26的4倍。)
注:这种倍数关系只适用于左移后被舍弃的高位不含1的情况,否则会溢出。
逻辑右移很简单,只要将二进制数整体右移,左边补0即可,如10101101逻辑右移一位为01010110
算术右移符号位要一起移动,并且在左边补上符号位,也就是如果符号位是1就补1符号位是0就补0 比如:11100算术右移一位为11110(符号位1跟着一起移动并且左边补了1)
(对于二进制的数值来说右移n位等于原来的数值除以2的n次方,比如10110100十进制是76(需要先将这个补码转换成原码之后再转换成十进制),右移两位后是11101101转成十进制是19恰好是76的1/4倍。)
例如数值2,用二进制表示为0010,左移一位变成了4,即0100.
那我说的你怎么看
A=1001=9
RL A=0011=3
A=9=00001001
RL A=00010010=0x12=18
因为A是8位的,你不能用4位来分析.
另外,移位相当于乘2的情况,不适用于移位前MSB为1的情况.