由於在編譯階段,只是檢查參數的引用類型。然而在運行時,Java虛擬機(JVM)指定對象的類型並且運行該對象的方法。因此在下面的例子中,b.move()之所以能編譯成功,是因為Animal類中存在move方法,所以編譯成功,然而運行時,運行的是特定對象的方法,即運行的是Dog類的move方法。而對Dog c而言,編譯階段首先是去Dog中查找bark(),因此能編譯成功,同時也能運行成功;但是對於b.bark()而言,首先是去Animal類中尋找bark(),因為找不到,因而編譯錯誤。
public class JavaOverrideOverload {
public static class Animal {
public void move() {
System.out.println("動物可以移動");
}
}
public static class Dog extends Animal {
public void move() {
System.out.println("狗可以跑和走");
}
public void bark() {
System.out.println("狗可以吠叫");
}
}
public static void main(String args[]) {
Animal a = new Animal(); // Animal 對象
Animal b = new Dog(); // Dog 對象
Dog c = new Dog();
a.move();// 執行 Animal 類的方法
b.move();// 執行 Dog 類的方法
b.bark();
c.bark();
}
}