function parameter evaluation order

后端 未结 5 1865
攒了一身酷
攒了一身酷 2020-11-22 07:37

In C and C++, is there a fixed order for evaluation of parameter to the function? I mean, what do the standards say? Is it left-to-right or right-to-left<

5条回答
  •  囚心锁ツ
    2020-11-22 08:04

    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.

提交回复
热议问题