短路运算是Java中&&和||的默认行为:只要能确定整个表达式真假值就停止计算后续操作数;&&在左操作数为false时跳过右操作数,||在左操作数为true时跳过右操作数,用于避免空指针、提供默认值等;&和|无短路特性,总是计算两边。

短路运算(Short-circuit Evaluation)是 Java 中 &&(逻辑与)和 ||(逻辑或)的默认行为:只要能确定整个表达式的真假值,就不再计算后续操作数。理解它,关键不是“跳过”,而是“按需求值”——不浪费计算,也避免副作用或异常。
短路与(&&):左边为假,右边不执行
表达式 a && b 中,Java 先计算 a:
- 若
a为false,整个结果必为false,b完全不执行(包括方法调用、变量读取、可能抛出的异常等); - 若
a为true,才继续计算b,最终结果取决于b的值。
常见用途:安全访问对象属性或避免空指针
例如:if (list != null && !list.isEmpty()) { ... } —— 若 list 为 null,isEmpty() 不会被调用,不会抛 NullPointerException。
短路或(||):左边为真,右边不执行
表达式 a || b 中,Java 先计算 a:
立即学习“Java免费学习笔记(深入)”;
- 若
a为true,整个结果必为true,b被跳过; - 若
a为false,才计算b,结果由b决定。
典型场景:提供默认值或条件触发
例如:String name = userName != null ? userName : "guest"; 可改写为更简洁的短路风格:String name = userName != null || (userName = "guest") != null ? userName : "guest";(不推荐这么写,仅说明原理);更实用的是:if (isValid() || tryRecover()) { ... } —— 先检查,失败再尝试恢复,且只在必要时调用 tryRecover()。
非短路运算符:& 和 | 的对比
Java 还提供了位运算符兼逻辑运算符的 & 和 |(用于布尔类型时):
- 它们总是计算左右两个操作数,无短路行为;
- 适用于需要强制执行右侧副作用的极少数情况(如日志、计数、资源清理),但一般应避免依赖这种副作用;
- 日常开发中,除非明确需要两边都执行,否则优先用
&&和||。
if (checkPermission() & logAccess()) { ... } 即使权限检查失败,logAccess() 仍会执行——看似“保险”,实则破坏逻辑清晰性,易引发误解和维护问题。
注意:短路只发生在布尔逻辑运算,不适用于其他运算符
短路是 && 和 || 的专属特性,与运算符优先级无关,也不适用于:
-
+、-、==、?:等所有其他运算符; - 三元运算符
?:的条件部分会执行,但只会执行?后或:后的一个分支(这是流程控制,不是短路); - 方法调用中的参数始终全部求值,无论方法体内是否用到——短路不穿透到参数列表。
foo(a(), b()) 中,a() 和 b() 总是都会先执行,哪怕 foo 内部只用到了第一个参数。
基本上就这些。短路不是语法糖,而是 Java 明确规定的求值策略,直接影响程序行为和健壮性。写条件时多问一句:“右边的表达式有没有副作用?能不能被跳过?”——答案往往帮你避开 bug。










