Is “++l *= m” undefined behaviour?

后端 未结 2 1805
暗喜
暗喜 2021-01-17 09:42

I have started studying about C++0x. I came across the follow expression somewhere:

int l = 1, m=2;
++l *= m;

I have no idea whether the se

相关标签:
2条回答
  • 2021-01-17 10:06

    In the code above, prefix ++ has precedence over *=, and so gets executed first. The result is that l equals 4.

    UPDATE: It is indeed undefined behavior. My assumption that precedence ruled was false.

    The reason is that l is both an lvalue and rvalue in *=, and also in ++. These two operations are not sequenced. Hence l is written (and read) twice "without a sequence point" (old standard wording), and behavior is undefined.

    As a sidenote, I presume your question stems from changes regarding sequence points in C++0x. C++0x has changed wording regarding "sequence points" to "sequenced before", to make the standard clearer. To my knowledge, this does not change the behavior of C++.

    UPDATE 2: It turns out there actually is a well defined sequencing as per sections 5.17(1), 5.17(7) and 5.3.2(1) of the N3126 draft for C++0x. @Johannes Schaub's answer is correct, and documents the sequencing of the statement. Credit should of course go to his answer.

    0 讨论(0)
  • 2021-01-17 10:06

    The expression is well defined in C++0x. A very Standardese quoting FAQ is given by Prasoon here.

    I'm not convinced that such a high ratio of (literal Standards quotes : explanatory text) is preferable, so I'm giving an additional small explanation: Remember that ++L is equivalent to L += 1, and that the value computation of that expression is sequenced after the increment of L. And in a *= b, value computation of expression a is sequenced before assignment of the multiplication result into a.

    What side effects do you have?

    • Increment
    • Assignment of the multiplication result

    Both side-effects are transitively sequenced by the above two sequenced after and sequenced before.

    0 讨论(0)
自定义标题
段落格式
字体
字号
代码语言
提交回复
热议问题