public class Test {
public static void main(String[] args) {
// 1、正数左移( << )
// 0000 0000 0000 0000 0000 0000 0000 0101 然后左移2位后,低位补0://
// 0000 0000 0000 0000 0000 0000 0001 0100 换算成10进制为20
System.out.println(5 << 2);// 运行结果是20
//如果是一直左移到该二进制的首位为1呢,其值如何 如下
/*左移29位得到:1010 0000 0000 0000 0000 0000 0000 0000
由于最高位为1,故为负数,此时应先减去1再取反得到
0110 0000 0000 0000 0000 0000 0000 0000 =Math.pow(2,30)+Math.pow(2,29)
*/
System.out.println(5 << 29);// 运行结果是-1610612736
// 2、正数右移( >> ) 高位补符号位
// 0000 0000 0000 0000 0000 0000 0000 0101 然后右移2位,高位补0:
// 0000 0000 0000 0000 0000 0000 0000 0001
System.out.println(5 >> 2);// 运行结果是1
System.out.println(5 >> 3);// 结果是0
// 3、负数右移,有符号右移高位补1,保证该数仍未负数,无符号右移( >>> ) 高位补0,通正数右移一致。
// 例如 -5换算成二进制后为:0101 取反加1为1011
// 1111 1111 1111 1111 1111 1111 1111 1011
// -5进行右移3位和无符号右移3位:
System.out.println(-5 >> 3);// 结果是-1
System.out.println(-5 >>> 3);// 结果是536870911
// 4、位与( & )
// 位与:第一个操作数的的第n位于第二个操作数的第n位如果都是1,那么结果的第n为也为1,否则为0
System.out.println(5 & 3);// 结果为1
System.out.println(4 & 1);// 结果为0
// 5、位或( | )
// 第一个操作数的的第n位于第二个操作数的第n位 只要有一个是1,那么结果的第n为也为1,否则为0
System.out.println(5 | 3);// 结果为7
// 6、位异或( ^ )
// 第一个操作数的的第n位于第二个操作数的第n位 相反,那么结果的第n为也为1,否则为0
System.out.println(5 ^ 3);//结果为6
// 5:0000 0000 0000 0000 0000 0000 0000 0101
//-5:1111 1111 1111 1111 1111 1111 1111 1011
//异或操作后:1111 1111 1111 1111 1111 1111 1111 1110=-2
System.out.println(5^-5); //结果为-2
// 7、位非( ~ )
// 操作数的第n位为1,那么结果的第n位为0,反之。
System.out.println(~5);// 结果为-6
}
}