移位运算符
一) 移位运算符的种类
java中的移位运算符一共分3种,它们分别是:
1 左移 <<
例: 3<<2 将数字3左移2位
3 转换为2进制数(4 bytes): 0000 0000 0000 0000 0000 0000 0000 0011
左移2位,低位补零: 0000 0000 0000 0000 0000 0000 0000 1100
再转换为十进制数: 12
2 带符号右移 >>
注: java中负数的存储以补码(符号位保持不变,其他位是存储数的绝对值按位取反加1)方式完成。 所以 int类型的-1 的二进制码将是: 11111111 11111111 11111111 11111111
例: -100>>4
-100转换为2进制数: 1000 0000 0000 0000 0000 0000 0110 0100
补码(注意符号位不变):1111 1111 1111 1111 1111 1111 1001 1100
带符号右移4位: 1111 1111 1111 1111 1111 1111 1111 1001
转换为原码(注意符号位不变): 1000 0000 0000 0000 0000 0000 0000 0111
再转换为十进制: -7
3 不带符号的右移 >>>
例: -1>>>10
-1的补码: 11111111 11111111 11111111 11111111
右移10位: 00000000 00111111 11111111 11111111
转换为十进制码: 4194303
二) 移位运算符的规则
1 移位运算符仅支持 byte char short int long 类型的值
2 byte char short 类型进行移位运算将“升级”为int类型。 int long类型进行移位运算分别保持4 bytes, 8 bytes不变。
3 对于byte、short、char和int进行移位时,实际移动的次数是移动次数和32的余数,也就是移位33次其实是移位1次得到的结果相同。移动long型的数值时,规定实际移动的次数是移动次数和64的余数,也就是移动66次其实是移动2次得到的结果相同。
三) 移位运算符与等号
i <<= 2; 等效于 i = i<<2;
i >>= 2; 等效于 i = i>>2;
i >>>= 2; 等效于 i = i>>>2;
例子1 :
int i = 12; //二进制为:0000000000000000000000000001100 i <<= 2; //i左移2位,把高位的两位数字(左侧开始)抛弃,低位的空位补0,二进制码就为0000000000000000000000000110000 System.out.println(i); //二进制110000值为48; 48 = 12*2*2