移位运算符

一) 移位运算符的种类
java中的移位运算符一共分3种,它们分别是:
[b]1 左移 <<[/b]
例: 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

[b]2 带符号右移 >>[/b]
注: 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

[b]3 不带符号的右移 >>>[/b]
例: -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
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值