循环移位就是把数值变成二进制,然后循环移动的过程。
换句话说,循环移位就是将移出的低位放到该数的高位(循环右移)或把移出的高位放到该数的低位(循环左移),左移,和右移动都是对整数进行的操作,在Win32控制台应用程序中,整形占4Byte节32bit。
循环左移的过程可以分为3步:
1、将x左端的n位先移动到y的低n位中,x(32-n);
2、将x左移n位,其右面低位补0,xn;
3、进行按位或运算(x (32 - n) | (x n));
循环右移的过程可以分为3步:
1、将x的左端的低n位先移动到y的高n位中x(32-n)
2、将x右移n位,其左面高n位补0xn;
3、进行按位或操作(x (32 - n) | (x n));
扩展资料
C语言实现循环移位:循环移位是对二进制序列进行操作,所以实现循环移位先需要将需要移位的数转换为二进制序列,然后按照上面描述的步骤进行移位,最后将移位后的二进制序列打印出来。
所谓循环移位是指在移位时不丢失移位前原范围的位,而是将它们作为另一端的补入位。例如循环右移n位,指各位右移n位,原来的低n位变成高n位,指各位右移n位,原来的低n位变成高n位。
用到循环移位的操作时,在汇编里面是比较容易实现的,ror,rol指令就行了。利用位运算进行循环移位操作比较容易理解。如果不是循环移位,使用xn(左移n位),xn右移n位。
参考资料来源:百度百科—循环移位运算
增加一个全局变量,将循环常数给变量,再对变量做左循环,将变量赋值给P0,
uchar a,b, c;
在主循环中P0=_crol_(P0,1); //P0的值向左循环移动
修改为
c=_crol_(c,1); //P0的值向左循环移动
P0=c;
: 是左移指令,低位补零。移出去的就消失了。
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倍。)
# include "reg51.h" // 包含头文件
#define uchar unsigned char
void delay02s(void) // 延时0.2s子程序
{
unsigned char i,j,k;
for ( i=2;i0;i-- )
for (j=200;j0;j-- )
for (k=250;k0;k-- );
}
void main (void) // 主函数
{
uchar i,j;
while (1) // 死循环
{
j=0x01; // j初始化为0x01,左移初始值
for(i=0;i8;i++) // for循环语句,完成8个循环
{
P1= ~ j; // 对变量j 中的值按位取反后,从P1口输出
delay02s( ); // 延时0.2s
j= j1; // 左移1位
}
j=0x80; // 设置右移初始值j为0x80
for (i=0;i8;i++)
{
P1= ~ j;
delay02s( );
j= j1; // 右移1位
}
}
}
首先对比一下 左边与右边 那里有不同 同时 程序不同对应的输出结构有哪些不同。。
P2口 连接8个LED 低电平驱动使其发光。
P2=0xfe //上电 P2.0连接的 LED发光。 其余的熄灭。
对比一下程序
void main() //主函数
{
P2=0xfe; //P2初始化
while(1) //死循环
{
num=P2; //这里 与左边不同 把P2的状态给 NUM 也就是0XFE num=0xfe
P2=_crol_(num,1); //P2等于num 循环左移 P2=0xef 这时应该是连接的P2.7的LED发光
delay(0);//延迟
}
}
左边 代码 NUM 每次大循环 都赋值 num=0xfe 是固定的 所以不管你以后怎么移动 P2口的输出都是不变得 只移动了一次。。
求采纳为满意回答。
单片机循环左右移的介绍就聊到这里吧,感谢您花时间阅读,谢谢。
本文标签:单片机循环左右移