Consider this function:
public static final int F(int a, int b) {
a = a - 1 + b;
// and some stuff
return a;
}
Is it required for implementations of JVMs to execute - 1
before + b
?
If we have a system profiler attached to the JVM, will we see the + b
operation being carried out before the + 1
operation?
Yes, Java follows the standard arithmetic order of operations.
Java enforces left-to-right for operators with the same precedence.
Operators in Java can be left-associative, right-associative, or have no associativity at all. Left-associative operators are assessed from left to right, right-associative operators are reviewed from right to left, and operators with no associativity are evaluated in any order.
Actually, I will disagree with the rest of the answers. The JLS §15.7 that people are referring to discusses the evaluation of operands. That is, in the expression
x = foo() - 1 + bar()
, in which order will the methods be invoked.
The relevant section is §15.7.3, which specifies
An implementation may not take advantage of algebraic identities such as the associative law to rewrite expressions into a more convenient computational order unless it can be proven that the replacement expression is equivalent in value and in its observable side effects [...]
Since the expression x = x - 1 + q
is equivalent in all ways to x = x + q - 1
, a conforming implementation is allowed to rewrite the expression (if it for some reason should decide that is more efficient).
Yes, it's in the Java language specification, §15.7.
The Java programming language guarantees that the operands of operators appear to be evaluated in a specific evaluation order, namely, from left to right.
It is recommended that code not rely crucially on this specification. Code is usually clearer when each expression contains at most one side effect, as its outermost operation, and when code does not depend on exactly which exception arises as a consequence of the left-to-right evaluation of expressions.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With