function parameter evaluation order

C and C++ are two completely different languages; don’t assume the same rules always apply to both. In the case of parameter evaluation order, however:

C99:

6.5.2.2 Function calls

10 The order of evaluation of the function designator, the actual arguments, and
subexpressions within the actual arguments is unspecified, but there is a sequence point
before the actual call.

[Edit]
C11 (draft):

6.5.2.2 Function calls

10 There is a sequence point after the evaluations of the function designator and the actual
arguments but before the actual call. Every evaluation in the calling function (including
other function calls) that is not otherwise specifically sequenced before or after the
execution of the body of the called function is indeterminately sequenced with respect to
the execution of the called function.94)

94) In other words, function executions do not ‘‘interleave’’ with each other.

C++:

5.2.2 Function call

8 The order of evaluation of arguments is unspecified. All side effects of argument expression evaluations take effect
before the function is entered. The order of evaluation of the postfix expression and the argument expression list is
unspecified.

Neither standard mandates the use of the hardware stack for passing function parameters; that’s an implementation detail. The C++ standard uses the term “unwinding the stack” to describe calling destructors for automatically created objects on the path from a try block to a throw-expression, but that’s it. Most popular architectures do pass parameters via a hardware stack, but it’s not universal.

[Edit]

I am getting confusing information from the books.

This is not in the least surprising, since easily 90% of books written about C are simply crap.

While the language standard isn’t a great resource for learning either C or C++, it’s good to have handy for questions like this. The official™ standards documents cost real money, but there are drafts that are freely available online, and should be good enough for most purposes.

The latest C99 draft (with updates since original publication) is available here. The latest pre-publication C11 draft (which was officially ratified last year) is available here. And a publicly availble draft of the C++ language is available here, although it has an explicit disclaimer that some of the information is incomplete or incorrect.

Leave a Comment