java静态分派_Java基础——重载、静态分派与动态分派
首先來看一段代碼
public class Human {}
public class Man extends Human{}
public class Woman extends Human{}
public class FulynDemo {
public void sayHello(Human arg) {
System.out.println("i am human");
}
public void sayHello(Man arg) {
System.out.println("i am man");
}
public void sayHello(Woman arg) {
System.out.println("i am woman");
}
public static void main(String[] args) {
FulynDemo demo = new FulynDemo();
Human arg = new Human();
Human arg1 = new Man();
Human arg2 = new Woman();
demo.sayHello(arg);
demo.sayHello(arg1);
demo.sayHello(arg2);
demo.sayHello((Man)arg1);
}
}
上述代碼的結果為:
可以看到,java中重載時選擇要執行的方法,是根據A a = new B()中的A類型參數來進行判斷的。這時的A,稱為變量的靜態類型或外觀類型,而B稱為實際類型。變量本身的靜態類型不會被改變,且最終的靜態類型在編譯期是可知的。而變量的實際類型可以改變,其變化的結果在運行期才可以確定,在編譯期變量的實際類型是不可知的。
上述代碼出現這樣的結果,是因為編譯器在重載時是通過參數的靜態類型而不是實際類型作為判定依據的,因為靜態類型在編譯期以知,故javac編譯器會根據靜態類型決定重載哪個版本,這(方法重載)便是靜態分派的一個場景了。下面可以介紹靜態分派的定義了:所有依賴于靜態類型來定位方法執行版本的分派動作稱為靜態分派。
下面再看另一個代碼的例子:
public class Human {
public void sayHello() {
System.out.println("i am human");
}
}
public class Man extends Human{
@Override
public void sayHello() {
System.out.println("i am man");
}
}
public class Woman extends Human{
@Override
public void sayHello() {
System.out.println("i am woman");
}
}
public class FulynDemo {
public static void main(String[] args) {
Human arg1 = new Man();
Human arg2 = new Woman();
arg1.sayHello();
arg2.sayHello();
arg2 = new Man();
arg2.sayHello();
}
}
上述代碼執行的結果為:
這段代碼顯然很容易理解,結果也不會出乎意料,這種在運行期間根據實際類型確定方法執行版本的分派過程,被稱為動態分派。
總結
以上是生活随笔為你收集整理的java静态分派_Java基础——重载、静态分派与动态分派的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: java删除第一个节点_访问单个节点的删
- 下一篇: java实现两个最大整数相加_JAVA-