1、右移,除以2右移n位除以2的n次方;
右移的概念和左移相反,就是往右边挪动若干位,运算符是>>;
右移对符号位的处理和左移不同,对于有符号整数来说,比如int类型,右移会保持符号位不变,例如:
inti=0x80000000;
i=i>>1;//i的值不会变成0x40000000,而会变成0xc0000000
2、左移,乘以2左移n位乘以2的n次方;
先说左移,左移就是把一个数的所有位都向左移动若干位,在C中用<<运算符。例如:inti=1;
i=i<<2;//把i里的值左移2位
左移就是:丢弃最高位,0补最低位
扩展资料
符号位向右移动后,正数的话补0,负数补1,也就是汇编语言中的算术右移。同样当移动的位数超过类型的长度时,会取余数,然后移动余数个位。
负数10100110>>5(假设字长为8位),则得到的是11111101
在C中,左移是逻辑/算术左移(两者完全相同),右移是算术右移,会保持符号位不变。实际应用中可以根据情况用左/右移做快速的乘/除运算,这样会比循环效率高很多。
每右移一位就是除以2,左移一位就是乘以2。C语言中,数字是二进制存储的,左移和右移就是变化为2的指数形式。
演示代码:
#include<stdio.h>
int main(){
int i = 2;
printf("i的值为%d\n",i);
printf("i向右一位后的值为:%d\n",i>>1);
printf("i向左一位后的值为:%d\n",i<<1);
return 0;
}
程序运行结果:
扩展程序
C语言中,移位运算符组成的表达式也属于算术表达式,其值为算术值。左移运算是将一个二进制位的操作数按指定移动的位数向左移动,移出位被丢弃,右边移出的空位一律补0。
右移运算是将一个二进制位的操作数按指定移动的位数向右移动,移出位被丢弃,左边移出的空位一律补0,或者补符号位,这由不同的机器而定。在使用补码作为机器数的机器中,正数的符号位为0,负数的符号位为1。
参考资料:百度百科-移位运算符
5的二进制表示是101
那么右移一位之后是10就是2了,是整除的
左移的话就是在后面补一个零,相当于是乘以二
那么变成了1010,十进制是10
那么右移一位之后是10就是2了,是整除的
左移的话就是在后面补一个零,相当于是乘以二
这两句不明白,可以通俗点吗?谢了
101右移,就是把最后一位拿掉了,是10,这个是二进制的,十进是2,5/2本来是小数的嘛,但这里是整数操作的,所以把小数部分去掉了
2012-01-09
若左移1位,其结果相当于将左值乘以2
左移,乘以2