Why is the phrase: “undefined behavior means the compiler can do anything it wants” true?

Nothing “causes” this to occur. Undefined behaviour cannot “occur”. There is no mystical force that descends upon your computer and suddenly makes it create black holes inside of cats.

That anything can happen when you run a program whose behaviour is undefined, is stated as fact by the C++ standard. It’s a statement of leeway, a handy excuse used by compilers to make assumptions about your code so as to provide useful optimisations.

For example, if we say that dereferencing nullptr is undefined (which it is) then no compiler needs to ever check that a pointer is not nullptr: it can just assume that a dereferenced pointer will never be nullptr, and if it’s not then any consequences are the programmer’s problem.

Due to the astounding complexity of compilers, some of those consequences can be rather unexpected.

Of course it is not actually true that “anything can happen”. Your computer has neither the necessary physical power nor the necessary legal authority to instantiate a black hole inside of a cat. But since C++ is an abstraction, it seems only fitting that we use abstractions to teach people not to write programs with undefined behaviour. If you program rigorously, assuming that “anything can happen” if your program has undefined behaviour, then you will not be surprised by said rather unexpected consequences, and you will not be tempted to try to “control” the outcome in any way.

Leave a Comment