Java:前置,后缀运算符优先级
关于Java中的运算符优先级,我有两个类似的问题。
int X = 10;System.out.println(X++ * ++X * X++); //it prints 1440
根据Oracle教程:
postfix(expr ,expr–)运算符的优先级高于前缀( expr,-expr)
因此,我假设该评估顺序为:
1) first postfix operator: X++ 1.a) X++ "replaced" by 10
1.b) X incremented by one: 10+1=11
At this step it should look like: System.out.println(10 * ++X * X++), X = 11;
2) second POSTfix operator: X++
2.a) X++ "replaced" by 11
2.b) X incremented by one: 11+1=12
At this step it should look like: System.out.println(10 * ++X * 11), X = 12;
3) prefix operator: ++X
3.a) X incremented by one: 12+1=13
3.b) ++X "replaced" by 13
At this step it should look like: System.out.println(10 * 13 * 11), X = 13;
4) evaluating 10*13 = 130, 130*11 = 1430.
但是Java似乎忽略了PRE / POST排序,而是将它们放在一个级别上。所以真正的顺序:
X++ -> ++X -> X++
是什么导致答案为(10 * 12 * 12)= 1440。
这个问题的例子:
int a=1, b=2; a = b + a++;
可接受的答案的一部分:“到分配时,(由于优先级)++
已经增加了a
to 的值2
,因此将=
覆盖该增加的值。”
好,让我们一步一步看:
1) replacing "b" with 2 2) replacing "a++" with 1
3) incrementing "a" by 1 -> at this point a==2
4) evaluating 2+1 = 3
5) overwriting incremented value of "a" with 3
似乎一切都很好。但是,让我们对该代码进行一些更改(将“ =”替换为“ + =“)
a += b + a++;
步骤1-4应该与上述相同。因此,在第4步之后,我们将得到以下内容:
a += 3;
哪里 a==2
然后我想:好吧,a = 2+3
,所以a
应该是5
。但是答案仅仅是4
我真的很困惑 我已经花了几个小时,但仍然无法理解我错了。
PS:我知道,我不应该在实际应用中使用这种“样式”。我只想了解我的想法出了什么问题。
回答:
混淆源于以下事实:操作数是从左到右 求值的 。 。
指定了此行为
因此X++ * ++X * X++
,首先评估为10 * 12 * 12
哪个产生1440,如您所见。
为了使自己信服,请考虑以下事项:
X = 10; System.out.println(X++ * ++X);X = 10; System.out.println(++X * X++);
如果X++
先完成,然后++X
再进行乘法,则两者都应打印相同的数字。
但是他们没有:
X = 10; System.out.println(X++ * ++X); // 120X = 10; System.out.println(++X * X++); // 121
那么,这有什么意义呢?好吧,如果我们认识到操作数是从左到右求值的,那么这很有意义。
X = 10; System.out.println(X++ * ++X); // 120 (10 * 12)X = 10; System.out.println(++X * X++); // 121 (11 * 11)
第一行看起来像
X++ * ++X10 (X=11) * (X=12) 12
10 * 12 = 120
第二个
++X * X++(X=11) 11 * 11 (X=12)
11 * 11 = 121
回答:
确实必须在乘法之前 执行 递增和递减 操作 。但这就是说:
Y = A * B++// Should be interpreted as
Y = A * (B++)
// and not
Y = (A * B)++
就像
Y = A + B * C// Should be interpreted as
Y = A + (B * C)
// and not
Y = (A + B) * C
仍然存在操作数 求值 的顺序是从左到右。
回答:
考虑以下程序:
class Test{
public static int a(){ System.out.println("a"); return 2; }
public static int b(){ System.out.println("b"); return 3; }
public static int c(){ System.out.println("c"); return 4; }
public static void main(String[] args)
{
System.out.println(a() + b() * c());
// Lets make it even more explicit
System.out.println(a() + (b() * c()));
}
}
如果参数进行 评估 的时候,他们需要的,无论是b
或c
将是第一位的,其他的未来,最后a
。但是,程序输出:
一个b
C
14
一个
b
C
14
因为,不管它们在方程式中需要和使用的顺序如何,它们仍然会从左到右 求值 。
有用的读物:
- Java中评估顺序的规则是什么?
- Java中的+ = a * a * a ++。如何评估?
- 附录A:Java中的运算符优先级
以上是 Java:前置,后缀运算符优先级 的全部内容, 来源链接: utcz.com/qa/399281.html