首页 >Java >java教程 >为什么 Java 中 `j = j` 的结果是 0,而 `a = b` 却将 `b` 增加到 1?

为什么 Java 中 `j = j` 的结果是 0,而 `a = b` 却将 `b` 增加到 1?

Mary-Kate Olsen
Mary-Kate Olsen原创
2024-11-04 08:44:01699浏览

Why does `j = j  ` result in 0 in Java, but `a = b  ` increments `b` to 1?

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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn