一、動態綁定的過程:
範例:
public class Son extends Father Son son = new Son();3 son.method();
1. 首先,編譯器根據物件的宣告型別和方法名,搜尋對應類(Son)及其父類別(Father)的“方法表”,找出所有存取屬性為public的method方法。
可能存在多個方法名為method的方法,只是參數類型或數量不同。
2. 然後,根據方法的「簽章」找出完全匹配的方法。
方法的名稱和參數清單稱為方法的簽章。
在Java SE 5.0 先前的版本中,覆寫父類別的方法時,要求傳回型別必須是一樣的。現在子類別覆寫父類別的方法時,允許其傳回類型定義為原始類型的子類型。
public Father getFather(){...} //父类中的方法 public Son getFather(){...} //子类覆盖父类中的getFather()方法
3. 如果是private、static、final 方法或是建構器,則編譯器明確地知道要呼叫哪一個方法,這種呼叫方式變成「靜態呼叫」。
4. 呼叫方法。
如果子類別Son中定義了method() 的方法,則直接呼叫子類別中的對應方法;如果子類別Son中沒有定義對應的方法,則到其父類別中尋找method()方法。
二、Demo
1. 子類別重寫父類別中的方法,呼叫子類別中的方法
public class Father{ public void method(){ System.out.println("父类方法:"+this.getClass()); } } public class Son extends Father{ public void method(){ System.out.println("子类方法"+this.getClass()); } public static void main(String[] args){ Father instance = new Son(); instance.method(); } } //结果:子类方法:class Son
2. 子類沒有重寫父類別中的方法,所以到父類別中尋找對應的方法
public class Father{ public void method(){ System.out.println("父类方法:"+this.getClass()); } } public class Son extends Father{ public static void main(String[] args){ Father instance = new Son(); instance.method(); } } //结果:父类方法:class Son
三、動態綁定只是針對物件的方法,對於屬性無效。因為屬性不能被重寫。
public class Father{ public String name = "父亲属性"; } public class Son extends Father{ public String name = "孩子属性"; public static void main(String[] args){ Father instance = new Son(); System.out.println(instance.name); } } //结果:父亲属性
以上是Java動態綁定機制怎麼實現的詳細內容。更多資訊請關注PHP中文網其他相關文章!