Skip to main content

What are operator precedence and the order of operand evaluation?

--
We had found precedence vs. order of evaluation and Re: *p++ great posts by Steve Summit in comp.lang.c. Here is summary of his posts in term of Java:

The important thing about precedence is not that it tells us in what order things will be evaluated. The important thing about precedence is that it tells us which operators are matched up with which operands. The precedence determines which operations will be performed first and not the order of operand evaluation.
The precedence can affect or influence order of evaluation. Now let's start looking at all of the ways that order of evaluation is determined by things other than precedence. In Java, operands are always evaluated from left to right.

For example, multiplication and division are done before addition and subtraction, because multiplication and division have higher precedence than addition and subtraction. Therefore, a + b *c is the same as a + (b*c), not (a+b)*c. The statement was probably made that "the multiplication happens first, before the addition, because multiplication has higher precedence than addition". And having heard an explanation like that, it's all too easy to come away with the impression that precedence controls order of evaluation, and it's also all too easy to get into trouble later when considering an expression like x = ++a + a++, where the precedence of post-fix increment does not control, doesn't even come close to controlling, the aspect of evaluation order that you're interested in.


If we look at the expression a + b * c very carefully, the key aspect explained by precedence is that the multiplication operator is applied to the operands b and c, and the addition operator is applied to a and the result of the multiplication. (Notice that we said "and", not "and then"). Here, although there's definitely an order of evaluation issue, and although the order of evaluation is apparently influenced by the precedence somehow, the influence is actually not a direct one. The real constraint on the order of evaluation is that we obviously can't complete an addition which involves the result of the multiplication until we've got the result of that multiplication. So we're probably going to have to do the multiplication first and the addition second, but this is mostly a consequence of causality, not precedence.

Another way to think about precedence is that it controls how the compiler parses expressions. Let's look at the expression x = a + b*c, which can be parenthesized as x = a + (b *c). Instead of parentheses, we can draw a "parse tree":
This data flow diagram shows another way to think about expression evaluation. Boxes represent values in memory, ovals represent operations, and arrows show the direction of data flow. The assignment operator ("=") is treated as an operator with low precedence by the compiler, but from a data flow point of view it only moves data so it's represented as an arrow, not an operation.

Once it has determined the parse tree, the compiler sets about emitting instructions (in some order) which will implement that parse tree. The shape of the tree may determine the ordering of some of the instructions, and precedence affects the shape of the tree. But the order of some operations may not even be strictly determined by the shape of the tree, let alone the precedence. So while precedence certainly has an influence on order of evaluation, precedence does not "determine" order of evaluation.
For an other example,

class Program {
  public static void main(String[] args) {
    int a = 1;
    int x = ++a + a++;
    System.out.println("Result is " + x);
  }
}
The result is 4. That means that ++a will be evaluated first and then evaluate a++.

Comments

Popular posts from this blog

Asynchronous Vs. Synchronous Communications

Synchronous (One thread):   1 thread -> |<---A---->||<----B---------->||<------C----->| Synchronous (multi-threaded):   thread A -> |<---A---->| \ thread B ------------> ->|<----B---------->| \ thread C ----------------------------------> ->|<------C----->|

WebSphere MQ Interview Questions

What is MQ and what does it do? Ans. MQ stands for MESSAGE QUEUEING. WebSphere MQ allows application programs to use message queuing to participate in message-driven processing. Application programs can communicate across different platforms by using the appropriate message queuing software products. What is Message driven process? Ans . When messages arrive on a queue, they can automatically start an application using triggering. If necessary, the applications can be stopped when the message (or messages) have been processed. What are advantages of the MQ? Ans. 1. Integration. 2. Asynchrony 3. Assured Delivery 4. Scalability. How does it support the Integration? Ans. Because the MQ is independent of the Operating System you use i.e. it may be Windows, Solaris,AIX.It is independent of the protocol (i.e. TCP/IP, LU6.2, SNA, NetBIOS, UDP).It is not required that both the sender and receiver should be running on the same platform What is Asynchrony? Ans. With messag...

Advantages & Disadvantages of Synchronous / Asynchronous Communications?

  Asynchronous Communication Advantages: Requests need not be targeted to specific server. Service need not be available when request is made. No blocking, so resources could be freed.  Could use connectionless protocol Disadvantages: Response times are unpredictable. Error handling usually more complex.  Usually requires connection-oriented protocol.  Harder to design apps Synchronous Communication Advantages: Easy to program Outcome is known immediately  Error recovery easier (usually)  Better real-time response (usually) Disadvantages: Service must be up and ready. Requestor blocks, held resources are “tied up”.  Usually requires connection-oriented protocol