My understanding was that static variables and static methods are of a class, not of the class objects. So an Override
of a static method won\'t work in Java, a
First of all there are different mechanisms involved here: Overriding and Shadowing (also called hiding).
1)
Static methods cannot be overriden as they are attached to the class they are defined in. However, you can shadow/hide a static method as you are doing with your Parent
/Child
class. This means, the method gets replaced in the Child
class but is still available from the Parent
class.
It gets more obvious that you are not overriding when you are calling the static methods from instances of those classes (and not using the Class.staticMethod()
invocation).
Parent parent = new Parent();
Child child1 = new Child();
Parent child2 = new Child();
parent.StaticMethod();
child1.StaticMethod();
child2.StaticMethod();
the output is
Static method from Parent
Static method from Child
Static method from Parent
The answer is the dispatch of the methods. You can grab the source code here
2)
The dispatch finds the method on the Parent
class. There is no dynamic dispatch as that the runtime type is used to find the method handle. It uses the compile time type. Remind: Calling static methods from instances is considered bad practice since things like above can happen and are easy to be overlooked.
3)
With final
you declare that the method cannot be overridden neither shadowed/hidden.
Although it is discouraged to ask 3 questions in one post, I am still willing to answer them.
Static methods cannot be overridden because there is no point of doing that. In your case, If you want to override the static method you can just call the method and add your own implementation after that or you just create another method.
So now that you know that static methods cannot be overridden. But you are asking why the third code works? The third code is the code with
public class Child extends Parent {}
right? Although static methods cannot be overridden, they can be inherited. What you are doing is inheriting Parent
so that is completely fine!
Parent
class, not overriding. That's why you get the output. A final
keyword means the method can never be changed, not even hidden. So that's why.You are confusing overriding with hiding