逻辑运算符:(返回类型为布尔值的表达式)
& 逻辑与 (可以翻译成并且)
| 逻辑或 (可以翻译成或者)
! 逻辑非 (取反)
&& 短路与
|| 短路或
通俗的例子理解"&"
汉语描述:100 大于 99 并且 100 大于 98,结果是有道理;
代码描述:100 > 99 & 100 > 98 , 结果是 true
public class OperatorTest1 {
public static void main(String[] args) {
int a = 100;
int b = 101;
int c = 90;
System.out.println("+++++++++++++++++逻辑与(&)+++++++++++++++++++++++");
System.out.println(a > c & c < b);
System.out.println("逻辑与(&)两真为真:"+(true & true));
System.out.println("逻辑与(&)两假为假:"+(false & false));
System.out.println("逻辑与(&)真假为假:"+(true & false));
System.out.println("+++++++++++++++++逻辑或(|)+++++++++++++++++++++++");
System.out.println(a > c | c > b);
System.out.println("逻辑或(|)两真为真:"+(true | true));
System.out.println("逻辑或(|)两假为假:"+(false | false));
System.out.println("逻辑或(|)真假为真:"+(true | false));
System.out.println("+++++++++++++++++取反(!)+++++++++++++++++++++++");
System.out.println("100大于90的取反结果为:"+!(100 > 90));
System.out.println(!true);
System.out.println(!false);
}
}
执行结果
短路与(&&)
什么是短路现象
符号两边的表达式,当右边的表达式不被执行时,就叫做短路现象。可观察下列程序中y和m的值
public class OperatorTest2 {
public static void main(String[] args) {
int x = 10;
int y = 11;
System.out.println("逻辑与(&):"+(x > y & x > y++));
System.out.println("逻辑与(&)右边表达式的值:"+y);
int n = 10;
int m = 11;
System.out.println("短路与(&&):"+(n > m && n > m++));
System.out.println("短路与(&&)右边的表达式:"+m);
}
}
由此可见,&与&& 的结果都为false,以上表达式的两边都为false,两个表达式的右边的y和m的值都是11且都做了++的操作。最后输出时,y=12,m=11。此时m++的操作并没有执行,所以此时就说短路与(&&)右边的表达式被短路了。
执行结果
什么时候使用短路与(&&),什么时候使用逻辑与(&)
从效率方面来说,&&比&的效率高一些。因为逻辑与&不管第一个表示式结果是什么,第二个表示式一定会执行(其实没必要再执行了,因为左边的表达式已经是false,那结果就已经确定为false了,所以就没有必要再执行右边的表达式了)。但是存在即合理。
在今后的开发中,短路与&&和逻辑与&还是需要同时存在使用的。大部分情况下都建议使用短路与&&,只有当既需要左边表达式执行,有需要右边表达式执行的时候,才会选择逻辑与&。
短路与(&&)和逻辑与(&)的区别
首先这两个运算符的运算结果没有任何区别,完全相同。只不过“短路与&&”会发生短路现象,当左边的表达式为false之后就短路了,&&右边的表达式就不被执行了。
短路或(||)
短路或(||)的时候只要一边是true,结果就是true。所以,当左边的表达式结果是true的时候,此时就短路了,右边的表达式就不需要执行了。
工作中遇到的例子
需求中一个接口允许前端传空字符、且需要匹配正则表达式:
[\w]:单词字符包括:a-z、A-Z、0-9,以及下划线, 包含 _ (下划线) 字符)。
[\u4E00-\u9FA5]:中文字符、
所以逻辑实现时,需要做以下的判断,同时运用上了短路与(&&)、短路或(||)、取反(!)
if(StringUtils.isNotEmpty(parameter) &&
!( parameter.matches("[\\w]+") || parameter.matches("[\\u4E00-\\u9FA5]+"))){
throw new MyException("不是合法的字符");
}
分析:当一个不合法的字符parameter传递过来时,StringUtils.isNotEmpty(parameter)结果为true,所以会走到短路与(&&)后面的表达式,因为正则表达式是逻辑或(||)匹配,所以只要有一个不匹配,结果就为false,又因为取反(不匹配才满足条件),所以短路与(&&)两边的表达式都为true,此时就满足了if条件,抛出了MyException。