开发者

Is this undefined behavior in C/C++

int foo(int c){
    return c;
}

int main(void){
    int a=5,c;
    c = foo(--a) + a; 
}

Will it invoke undefined behavior in C/C++? I think no it won't.

After reading all the answers I can't figure out whether it is undefi开发者_StackOverflow中文版ned behavior or unspecified behavior.


Yes it's undefined behavior - a and foo(--a) can be evaluated in any order.

For further reference, see e.g. Sequence Point. There's a sequence point after the complete expression, and after evaluation of the argument to foo - but the order of evaluation of subexpressions is unspecified, per 5/4:

Except where noted, the order of evaluation of operands of individual operators and subexpressions of individual expressions, and the order in which side effects take place, is unspecified. Between the previous and next sequence point a scalar object shall have its stored value modified at most once by the evaluation of an expression. Furthermore, the prior value shall be accessed only to determine the value to be stored. The requirements of this paragraph shall be met for each allowable ordering of the subexpressions of a full expression; otherwise the behavior is undefined.

EDIT: As Prasoon points out, the behavior is unspecified due to the order of evaluation ... is unspecified., and becomes undefined due to the prior value shall be accessed only to determine the value to be stored


You should read this, it will tell you that your code is undefined because + is not a sequence point and as such it is undefined whether f(--a) or a is evaluated first.


Even though the operands of + operator can be evaluated in either order the behaviour is undefined because it violates the 2nd rule

1) Between the previous and next sequence point an object shall have its stored value modified at most once by the evaluation of an expression.

2) Furthermore, the prior value shall be accessed only to determine the value to be stored.

The following is well defined

c = foo(a-1) + a ;

Read this FAQ entry for a better understanding of undefined behaviour and sequence points.


According to Wikipedia + is not a sequence point, so the order of evaluation is not fixed, hence you have undefined behavior.


You will get warning for return type in main function else it is ok and c = 8 at the end of main().

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜