Java中&、|、&&、||详解

  1. &:按位与,也叫逻辑与。&的两侧可以是int,也可以是boolean表达式
//第一种情况:&的两侧是int
//当&两侧是int时,要先把运算符两侧的数转化为二进制数再进行运算
//12 转为二进制  0000 1100
//5 转为二进制   0000 0101
// 1为真,0为假,按逻辑,只有前后都为真,结果才为真 也就是只有在 1&1 时,结果才为1 ,其他情况结果都是0
// 所以返回结果是 0000 0100,转为10进制数就是4
System.out.println(12 & 5);//4

//第二种情况:&的两侧是boolean表达式
//特点:两侧的boolean表达式都要执行计算
int i = 2;
//++i==2  先进行i自增,i=3,再进行i==2,返回false
//i++==3  先进行i==3,返回true,然后i自增,i=4
System.out.println((++i==2) & (i++==3));//false
System.out.println(i);//4  可以简单来想,因为前后的boolean表达式都会计算,那么i有2次++,就会加2。
  1. &&:短路与。两侧要求必须是布尔表达式

特点:左侧的boolean表达式执行计算为false时,右侧被短路,不会执行计算,直接返回结果为false

int k = 2;
//++k==2  先进行i自增,k=3,再进行k==2,返回false
//k++==3  不会执行
System.out.println((++k==2) && (k++==3));//false
System.out.println(k);//3  可以简单来想,因为只有左侧的boolean表达式执行计算,那么k只有1次++,就会只加1。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值