[cfe-dev] libc++ does not throw an exception where libstdc++ does

Tim Northover t.p.northover at gmail.com
Sat Jun 29 12:48:27 PDT 2013


> Thanks for your reply -- so I guess if it doesn't get implicitly
> defaulted to false, then the exception may not be thrown, but this
> does not explain why the cout<< behaviour I outline above happens.

That's just luck of the draw. The compiler is supposed to make sure
well-defined programs behave as they should but is free to do whatever
it wants to ones with undefined behaviour.

My very vague guess is that the extra cout calls sit in between the
uninitialised variable and its use, making the optimiser think that
something may be setting it properly in there. Without those calls it
could be aggressively pruning code based on, well, anything really.
Some test that makes sense on a well-defined value but not an
uninitialised one, probably -- but it could be doing it merely for the
shits and giggles.

> ... and I thought whether such scalar values are given some default
> values are not will be decided by the compiler implementation and not
> by the standard library that is being used. What if I did not use the
> standard library at all?

It's uninitialised in all cases, but what effect that has can hinge on
tiny changes to the code pulled in by the library. Perhaps one version
writes "if (cond)" and the other writes "if (!cond)" and LLVM treats
them differently.

Actually, in my experience bools are even more prone to this than
other types. At least an unitinitialised area of memory pointing at an
int has *some* value. Bool memory can be in a state that really means
nothing since they take up 8 bits (usually) and only values 0 and 1
are used (usually). Of course, that may not be what's happening here
and things will go wrong with uninitialised values of other types as
well, it's just one more type of error for bools.

Tim.



More information about the cfe-dev mailing list