移位操作符只针对整数型,不能由于浮点型
1、一个正的整数型变量用上左移操作符有乘以二的效果
如: int a = 7;
int b = a << 1;
最后a的值不变,b的值乘以2。即 a=7;b=14;
2、一个负的整数型变量用上左移操作符也有乘以二的效果
如: int a = -7;
int b = a << 1;
最后a的值不变,b的值乘以2。即 a=-7;b=-14;
3、源码、反码及补码是整数的二进制表示方式,整数在内存中存的是补码,所以移位操作符进行的是补码的操作。
正的整数原码、反码及补码是相同的
负的整数原码、反码及补码是要计算的
比如 7,它的二进制是 111是int类型,一个 int 类型变量占四个字节,一个字节 8 个比特位
所以 7 的二进制序列原码为 0000 0000 0000 0000 0000 0000 0000 0111,因为 7 是正数,所以它最左位(最高位或符号位)为 0 ,又因为正的整数原码、反码及补码是相同的。
所以 7
原码为 0000 0000 0000 0000 0000 0000 0000 0111
反码为 0000 0000 0000 0000 0000 0000 0000 0111
补码为 0000 0000 0000 0000 0000 0000 0000 0111
如果是 -7,则它的原码最高位变为1(正的就为0,负的就为1)其它不变,而反码则为原码最高位(符号位)不变,其它数字取反,及 0 变1,1 变 0 ,而反码加 1 则变为补码
所以 -7
原码为 1000 0000 0000 0000 0000 0000 0000 0111
反码为 1111 1111 1111 1111 1111 1111 1111 1000
补码为 1111 1111 1111 1111 1111 1111 1111 1001
4、左移操作符
7 << 1 其实是补码最左边去掉一个,然后最右边补上一个 0 ,形成新的补码,又因为正的整数原码、反码及补码是相同的,新的补码又形成新的反码及新的原码,而新的原码代表的是 7 左位移 1 的整数型,它是 14。
-7 << 1 其实也是补码最左边去掉一个,然后最右边补上一个 0 ,形成新的补码,又因为负的整数原码、反码及补码是不同的,新的补码减 1 (减 1 是因为反码加 1 变为补码)形成新的反码,新的反码最左位(最高位)不变其它取反形成新的原码,而新的原码代表的是 -7 左位移 1 的整数型,它是 -14。
左移有乘二的效果。
5、右移操作符(有两种位移方法)
(1)算数位移(右边去掉,左边补原符号位)(一般采用此方法)
7 >> 1 补码最右边去掉 1 位,最左边补上一位,如果是正数则补 0 ,负数则补 1 ,7 是正数所以补上 0 ,换成原码最后结果是 3 (正数有除以二的效果)
(2)逻辑位移(右边去掉,左边直接补0)