逻辑运算符与计算机中的移位 -2009-2

来源:互联网 发布:linux运维工资高吗 编辑:程序博客网 时间:2024/06/05 21:21
&与&&的区别
1.相同点
public class Test2{
    public static void main(String[] args){
        int i=3;
        if((i++>5)&&(i++<9)){
            System.out.println(i);
            System.out.println("恭喜,执行完了条件语句!");
        }    
        System.out.println(i);
    }
}
1、&与&&都是逻辑运算符,当两侧表达式都为真的时候才执行{}中的语句,/
2、但是&符号如果前面为假,仍然会执行i++<9的语句
&&则不会执行  所以本例子i为4 若换成&则为5
3、&还是逻辑与运算符


移位
<<:左移 左边最高位丢弃,右边补齐0


原理  0110 1*2^2+1*2^1=6
左移1位  
 01100 1*2^3+1*2^2=12=2*(1*2^2+1*2^1)=1*2^1*原值
 结论  正数左移移X位即原值*2^x
正数右移X位即原值/2^x


>>:右移 最高位是0,左边补齐0;最高为是1,左边补齐1
>>>:无符号右移 无论最高位是0还是1,左边补齐0

面试题:
请用最有效率的方式写出计算2乘以8的结果?
2 * 8

2 << 3


*/
class OperatorDemo3 {
public static void main(String[] args) {
//<< 把<<左边的数据乘以2的移动次幂
System.out.println(3 << 2); //3*2^2 = 3*4 = 12;

//>> 把>>左边的数据除以2的移动次幂
System.out.println(24 >> 2); //24 / 2^2 = 24 / 4 = 6
System.out.println(24 >>> 2);

System.out.println(-24 >> 2); 
System.out.println(-24 >>> 2);
}
}
/*
计算出3的二进制:11
00000000 00000000 00000000 00000011
(00)000000 00000000 00000000 0000001100

>>的移动:
计算出24的二进制:11000
原码:10000000 00000000 00000000 00011000
反码:11111111 11111111 11111111 11100111
补码:11111111 11111111 11111111 11101000

11111111 11111111 11111111 11101000
1111111111 11111111 11111111 111010(00) 补码

补码:1111111111 11111111 11111111 111010
反码:1111111111 11111111 11111111 111001
原码:1000000000 00000000 00000000 000110

结果:-6

>>>的移动:
计算出24的二进制:11000
原码:10000000 00000000 00000000 00011000
反码:11111111 11111111 11111111 11100111
补码:11111111 11111111 11111111 11101000

11111111 11111111 11111111 11101000
0011111111 11111111 11111111 111010(00)
0 0