java中有三种移位运算符
<< : 左移运算符,num << 1,相当于num乘以2
: 右移运算符,num >> 1,相当于num除以2
: 无符号右移,忽略符号位,空位都以0补齐
下面来看看这些移位运算都是怎样使用的
复制代码
1 /
2
3 /
4 package com.b510.test;
5
6 /
7 @author Jone Hongten
8 @create date:2013-11-2
9 @version 1.0
10 /
11 public class Test {
12
13 public static void main(String[] args) {
14 int number = 10;
15 //原始数二进制
16 printInfo(number);
17 number = number << 1;
18 //左移一位
19 printInfo(number);
20 number = number >> 1;
21 //右移一位
22 printInfo(number);
23 }
24
25 /*
26 输出一个int的二进制数
27 @param num
28 /
29 private static void printInfo(int num){
30 System.out.println(Integer.toBinaryString(num));
31 }
32 }
复制代码
运行结果为:
1010
10100
1010
我们把上面的结果对齐一下:
1010 十进制:10 原始数 number
10100 十进制:20 左移一位 number = number << 1;
1010 十进制:10 右移一位 number = number >> 1;
看了上面的demo,现在是不是对左移和右移了解了很多了呢
对于:>>>
无符号右移,忽略符号位,空位都以0补齐
value >>> num -- num 指定要移位值value 移动的位数。
无符号右移的规则只记住一点:忽略了符号位扩展,0补最高位 无符号右移运算符>>> 只是对32位和64位的值有意义
热门评论
只是对32位与64位的值有意义这点说的太模糊了。可以做如下总结:
该数对应的二进制码补码整体右移,左边部分总是以0填充,右边超出的部分舍弃.
并且由于:正数的补码为其原码,负数的补码是反码加1。
所以如下:
正数的>>>和>>一样 正数的>>>n位等于===原操作数/2^n
负数取补码,然后右移。例如,-2的补码是 11111111 11111111 11111111 11111110。右移一位得到:
01111111 11111111 11111111 11111111,其十进制的值为 2147483647,所以 -2>>>1 的值是 2147483647