C语言中 移位左移和循环左移,有区别吗

我现在用的C语言,如果想一个byte的数据,左移(或者右移)8次之后,仍旧便会原始的数据,该用什么指令?

  在C中,左移是逻辑算术,右移是算术右移,会保持符号位不变.
  实际应用中可以根据情况用左/右移做快速的乘/除运算,这样会比循环效率高很多.
  1、左移就是把一个数的所有位都向左移动若干位,在C中用<<运算符.例如:
int i = 1;
i = i << 2; //把i里的值左移2位
也就是说,1的2进制是000...0001(这里1前面0的个数和int的位数有关,32位机器,gcc里有31个0),左移2位之后变成 000...0100,也就是10进制的4,所以说左移1位相当于乘以2,那么左移n位就是乘以2的n次方了。
  2、右移对符号位的处理和左移不同,对于有符号整数来说,比如int类型,右移会保持符号位不变,例如:
int i = 0x80000000;
i = i >> 1; //i的值不会变成0x40000000,而会变成0xc0000000
就是说,符号位向右移动后,正数的话补0,负数补1,也就是汇编语言中的算术右移.同样当移动的位数超过类型的长度时,会取余数,然后移动余数个位.
温馨提示:答案为网友推荐,仅供参考
第1个回答  2012-05-10
移位左移就是在二进制数的左侧补0,补多少个0,右侧就去除几位。循环左移不用去除
第2个回答  2012-05-10
比方说一个btye里面存着下列数据11010101
位置左移则最右边补个0为10101010
循环左移是把最左边的1挪动到右边去,依次循环下去
第3个回答  推荐于2017-09-30
首先说这不是C语言吧
应该说是汇编语言
比方说一个btye里面存着下列数据11010101
位置左移则最右边补个0为10101010
循环左移是把最左边的1挪动到右边去(或者CF中)
如果不考虑CF则为10101011
考虑CF
CF=1时候10101011
CF=0时候10101010本回答被提问者采纳
第4个回答  2012-05-10
有的
相似回答