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

&与&&的区别
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
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值