Because if (true)
and if (false)
are a special case. The compiler specifically allows them, by design, because often developers will want to temporarily enable or disable code. It’s kind of like Java’s version of #ifdef
in C.
From the Unreachable Statements section of the Java Language Specification:
…the superficially similar case:
if (false) { x=3; }
does not result in a compile-time error. An optimizing compiler may realize that the statement x=3; will never be executed and may choose to omit the code for that statement from the generated class file, but the statement x=3; is not regarded as "unreachable" in the technical sense specified here.
The rationale for this differing treatment is to allow programmers to define "flag" variables such as:
static final boolean DEBUG = false;
and then write code such as:
if (DEBUG) { x=3; }
The idea is that it should be possible to change the value of DEBUG from false to true or from true to false and then compile the code correctly with no other changes to the program text.