首页 > 学院 > 开发设计 > 正文

java中的位操作

2019-11-14 09:17:16
字体:
来源:转载
供稿:网友
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 } }
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表