问题
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, then default methods become irrelevant. A default method cannot override a method from java.lang.Object. The reasoning is very simple, it’s because Object is the base class for all the java classes. So even if we have Object class methods defined as default methods in interfaces, it will be useless because Object class method will always be used. That’s why to avoid confusion, we can’t have default methods that are overriding Object class methods.
I quickly tried following code to confirm the behavior
public class DefaultMethodClass {
public void defaultMethod()
{
System.out.println("DefaultMethodClass.defaultMethod()");
}
}
public interface DefaultMethodInterface {
public default void defaultMethod()
{
System.out.println("DefaultMethodInterface.defaultMethod()");
}
}
public class DefaultMethodClassInterfaceChild extends DefaultMethodClass implements DefaultMethodInterface
{
public static void main(String[] args) {
(new DefaultMethodClassInterfaceChild()).defaultMethod();
}
}
This prints
DefaultMethodClass.defaultMethod()
I am not able to see any specific reason behind why this particular behavior is chosen by language designer. Is their any such significant reason that I am missing? Or its just that interface default method logically bears lesser importance than concrete implementation provided by the super class?
回答1:
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.
回答2:
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.
来源:https://stackoverflow.com/questions/51520338/significance-of-inheriting-method-from-superclass-instead-of-default-method-from