gpt4 book ai didi

java - 增量器逻辑

转载 作者:IT老高 更新时间:2023-10-28 20:46:13 24 4
gpt4 key购买 nike

我正在尝试更深入地使用 post 和 pre 增量器,但我有点坚持以下表达式:

public static void main(String[] args) {
int i = 0;
i = i+=(++i + (i+=2 + --i) - ++i);
// i = 0 + (++i + (i+=2 + --i) - ++i);
// i = 0 + (1 + (3 + 2) - 1 );
// i = 0 + (6 - 1 );
System.out.println(i); // Prints 0 instead of 5
}

我知道我在某处遗漏了逻辑,但在哪里?

我尝试过的:

  • 从左到右(虽然我知道不推荐)
  • 从最里面的括号开始,从那里开始。

感谢您的帮助

PS:评论是我微积分的细节

编辑 1

我尝试将表达式中的硬编码值从 2 更改为其他值,结果总是给出 0

看看这个例子:

    int i = 0;
i = i+=(++i + (i+=32500 + --i) - ++i);
System.out.println(i); // Prints 0

这个表达式在逻辑上应该离 0 不远,但它确实打印了它。

当我使用否定时也会发生同样的情况:

    int i = 0;
i = i+=(++i + (i+=(-32650) + --i) - ++i);
System.out.println(i); // Prints 0

编辑 2

现在,我将 i 的值改为:

    int i = 1;
i = i+=(++i + (i+=2 + --i) - ++i);
System.out.println(i); // Prints 2

i = 2;
i = i+=(++i + (i+=10000 + --i) - ++i);
System.out.println(i); // Prints 4

i = 3;
i = i+=(++i + (i+=(-32650) + --i) - ++i);
System.out.println(i); // Prints 6

无论硬编码的值是什么,它每次都会给出 i 的双倍。

最佳答案

引用 Java Language Specification, 15.7 Evaluation Order :

The Java programming language guarantees that the operands of operators appear to be evaluated in a specific evaluation order, namely, from left to right.

The left-hand operand of a binary operator appears to be fully evaluated before any part of the right-hand operand is evaluated.

If the operator is a compound-assignment operator (§15.26.2), then evaluation of the left-hand operand includes both remembering the variable that the left-hand operand denotes and fetching and saving that variable's value for use in the implied binary operation.

所以,本质上,i +=++i 将记住左侧 i 的旧值,评估右侧一边。

请记住,操作数的求值顺序和运算符的优先级是两个不同的东西。

逐步显示评估顺序,并在 {braces} 中保存值:

int i = 0;
i = i += (++i + (i += 2 + --i) - ++i); // i = 0
i{0} = i += (++i + (i += 2 + --i) - ++i); // i = 0
i{0} = i{0} += (++i + (i += 2 + --i) - ++i); // i = 0
i{0} = i{0} += (1 + (i += 2 + --i) - ++i); // i = 1
i{0} = i{0} += (1 + (i{1} += 2 + --i) - ++i); // i = 1
i{0} = i{0} += (1 + (i{1} += 2 + 0 ) - ++i); // i = 0
i{0} = i{0} += (1 + (i{1} += 2 ) - ++i); // i = 0
i{0} = i{0} += (1 + 3 - ++i); // i = 3
i{0} = i{0} += (4 - ++i); // i = 3
i{0} = i{0} += (4 - 4 ); // i = 4
i{0} = i{0} += 0 ; // i = 4
i{0} = 0 ; // i = 0
0 ; // i = 0

跟进问题的修改

如果我们将初始值命名为I和常量N:

int i = I;
i = i += (++i + (i += N + --i) - ++i);

那么我们可以看到这些值为:

i{I} = i{I} += ((I+1) + (i{I+1} += N + I) - ((I+1+N+I)+1));
i{I} = i{I} += (I + 1 + (I + 1 + N + I) - (I + 1 + N + I + 1));
i{I} = i{I} += (I + 1 + I + 1 + N + I - I - 1 - N - I - 1);
i{I} = i{I} += I;
i{I} = I + I;
i = 2 * I;

关于java - 增量器逻辑,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33120663/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com