Why "extends" precedes "implements" in class declaration

lzjun picture lzjun · May 10, 2012 · Viewed 61.8k times · Source

Why must implement always be written after extend in a class declaration? For example:

public class Register extends ActionSupport implements ModelDriven

Why can it not be:

public class Register implements ModelDriven extends ActionSupport 

The latter produces a compile-time error.

Answer

Nathaniel Ford picture Nathaniel Ford · May 10, 2012

When the Java compiler turns a class into bytecode, it must first look to a parent class. That is because the underlying implementation of classes is to point to the bytecode of the parent class - which holds the relevant methods and fields. Then it adds in pointers to the code of the child class functions - some of which are mandated by the 'implements' keyword.

Because the parent class must be compilable, it is easier if the compiler knows up front what that class is. Further, you can extend only one class but implement any number of interfaces. The compilation time climbs if the extends keyword can be intermingled amongst any number of implements instructions. Compilers want to fail as fast as possible to decrease dev time, so this choice is logical. Further, it helps you think clearly about the class for the same reason.