Section 12.2.5 of the standard says:
A temporary bound to a reference parameter in a function call (5.2.2) persists until the completion of the full expression containing the call. A temporary bound to the returned value in a function return statement (6.6.3) persists until the function exits. In all these cases, the temporaries created during the evaluation of the expression initializing the reference, except the temporary to which the reference is bound, are destroyed at the end of the full-expression in which they are created and in the reverse order of the completion of their construction.
I'm trying to understand the following code:
#include <iostream>
const int& foo(const int& fooRef)
{
return fooRef;
} // #0
int main (void)
{
const int& numberRef = foo(5); // #1
std::cout << numberRef; // #2
return 0;
}
On line #1
a temporary object is created and bound to fooRef
. fooRef
is destroyed on line #0
. I thought the temporary should be destroyed here since lifetime-extension is not transitive.
Questions:
What does
until the function exits
mean? Does it meanuntill it finished executing
?Why do I get a
5
output. Does a temporary object still exist on line#2
?How can I interpret the standard quote to figure out how this example works?
Step-by-step atomic walk-through with references to the standard would be greatly appreciated. Thank you!
P. S. An accepted answer here also told the the code is broken
and I do not get, why I get such output of program.
5
. When I compile it with the-O2
flag, I actually get output0
. Adding the option-Wall
warns about using uninitialized values. On the contrary, using clang++ always results in5
printed and no warning message, independent of compiler options used. But don't rely on that behaviour! – Vaudeville