2、>>表示右移(有符号右移),如:15>>2的结果是3,-31>>3的结果是-4,左边以该数的符号位补充,移出的部分将被抛弃。
转为二进制的形式可能更好理解(省略左边的三个字节),0000 1111(15)右移2位的结果是0000 0011(3),1110 0001(-31)右移3位的结果是1111 1100(-4)。
3、>>>也表示右移,但是是无符号右移,如:15>>>2的结果是3,-31>>>3的结果是536870908,移出的部分将被抛弃:
同样转为二进制的形式,00000000 00000000 00000000 00001111(15)右移2位的结果是00000000 00000000 00000000 00000011(3),
11111111 11111111 11111111 11100001(-31)右移3位的结果是00011111 11111111 11111111 11111100(536870908)。
测试代码如下:
public class Test {
public static void main(String[] args) {
System.out.println("1、测试>:");
int a = 1, b = 2;
System.out.println(a > b);
System.out.println("/n2、测试>>:");
System.out.println("15 >> 2 = " + (15 >> 2));
System.out.println("-31 >> 3 = " + (-31 >> 3));
System.out.println("/n3、测试>>>:");
Integer i = -31;
System.out.println("-31:/t/t" + Integer.toBinaryString(i) + "," + i);
System.out.println("-31 >> 3:/t" + Integer.toBinaryString(i >> 3) + "," + (i >> 3));
System.out.println("-31 >>> 3:/t" + Integer.toBinaryString(i >>> 3) + "," + (i >>> 3));
}
}
测试结果如下:
1、测试>:false2、测试>>: 15 >> 2 = 3-31 >> 3 = -43、测试>>>:-31: 111111