Java 中的后置自增运算符
Java 后置自增运算符 ( ) 由于其独特的行为,常常让程序员感到困惑。在本文中,我们将探讨后增量运算符的复杂性,并解释为什么 Joshua Bloch 的“Java Puzzlers”中的以下代码片段会产生意外结果:
<code class="java">public class Test22 { public static void main(String[] args) { int j = 0; for (int i = 0; i < 100; i++) { j = j++; } System.out.println(j); // prints 0 int a = 0, b = 0; a = b++; System.out.println(a); System.out.println(b); // prints 1 } }</code>
根据作者的解释,表达式j = j 的行为应类似于以下内容:
<code class="java">temp = j; j = j + 1; j = temp;</code>
此逻辑意味着 j 的值应递增,然后分配给 j,从而产生类似于表达式 a = b 的增量。然而,在后一种情况下,后增量运算符在不同的上下文中使用,导致不同的结果。
a = b 的正确计算实际上如下:
<code class="java">temp = b; b = b + 1; // increment a = temp; // then assign</code>
这与 Java 语言规范 (JLS) 一致,该规范规定,对于后缀增量表达式,“将值 1 添加到变量的值中,并将总和存储回变量中”。因此,a = b 在将 b 递增到 1 之前将 b (0) 的原始值赋给 a。
返回表达式 j = j ,我们现在可以看到后递增运算符导致 j 被计算在增量之前,导致常量赋值为0。作者解释中添加的temp变量实际上并没有参与后增量求值。
通过了解后增量运算符的真实行为,我们可以避免混淆并确保准确的代码执行。
以上是为什么 Java 中 `j = j` 的结果是 0,而 `a = b` 却将 `b` 增加到 1?的详细内容。更多信息请关注PHP中文网其他相关文章!