I came across following paragraph while reading about java 8 default methods from here:
If any class in the hierarchy has a method with same signature
Answer is simple: you are allowed to implement multiple interface
but you can just extend one class
. Indeed you can't have multiple default
methods with the same name by implementing multiple interfaces.
If in any circumstance a default
method has higher priority than a method implemented inside a real class in the hierarchy you end up having the same exact problem for which Java designers didn't want multiple inheritance: ambiguity.
As a personal opinion: a default method is seen as a "implementation of a functionality when none is defined", if the method is defined in a real class it is expected to be a more specific implementation.
I am not able to see any specific reason behind why this particular behavior is chosen by language designer.
Method definitions were in Java 1.0, Interface default methods where added in Java 8. Code written for Java 1.0 still needs to work.
Or its just that interface default method logically bears lesser importance than concrete implementation provided by the super class?
Effectively they have lesser importance being added after 20+ years of existing code being written.