java中的位操作

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 
    } 
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值