
本文详解 java 中 `--x` 与 `x + --x` 等混合表达式的执行逻辑,揭示看似矛盾的输出(如 `7` 和 `6`)实则源于操作数求值顺序(从左到右)与副作用发生的时序,而非单纯依赖运算符优先级。
在 Java 中,理解 x + --x 与 --y + y 输出不同结果(7 和 6)的关键,在于厘清两个核心机制:运算符优先级(precedence) 与 操作数求值顺序(evaluation order)。许多开发者误以为“前置递减优先级高,就一定先整体执行”,但 Java 规范明确要求:所有操作数必须从左到右依次求值,且每个操作数的副作用(如变量修改)在该操作数求值完成后立即生效。
以代码为例:
int x = 4, y = 4; System.out.println(x + --x); // 输出 7 System.out.println(--y + y); // 输出 6
我们逐行分析:
-
x + --x:
立即学习“Java免费学习笔记(深入)”;
- 先求左边操作数 x → 得到值 4(此时 x 仍为 4);
- 再求右边操作数 --x → 先将 x 减 1(x 变为 3),再返回新值 3;
- 执行加法:4 + 3 = 7。
✅ 最终 x == 3,输出 7。
-
--y + y:
- 先求左边操作数 --y → 先将 y 减 1(y 变为 3),再返回 3;
- 再求右边操作数 y → 此时 y 已是 3,直接取值 3;
- 执行加法:3 + 3 = 6。
✅ 最终 y == 3,输出 6。
⚠️ 重要提醒:
- 运算符优先级只决定表达式结构如何分组(例如 --x + y 等价于 (--x) + y,而非 --(x + y)),不决定求值时机;
- Java 严格采用从左到右的操作数求值顺序(JLS §15.7);
- 在同一表达式中多次读写同一变量(如 x + --x)属于未定义行为的灰色地带——虽然 Java 规范明确定义了该场景(有确定结果),但此类代码严重损害可读性与可维护性,应绝对避免。
✅ 推荐实践:将自增/自减操作单独成句,保持语义清晰:
int x = 4; int y = 4; // 清晰、安全、符合直觉 x--; System.out.println(x + x); // 3 + 3 = 6 --y; System.out.println(y + y); // 3 + 3 = 6
总结:7 和 6 的差异不是“bug”或“例外”,而是 Java 求值模型严谨性的体现。真正需要警惕的,是依赖副作用顺序编写脆弱表达式。写出明确、无歧义的代码,永远比“理解规则”更重要。










