java - 多態(tài)調(diào)用同名成員變量,為何訪問的是父類的成員變量?
問題描述
剛開始猜測,由于父類和子類的成員變量在堆中各存一份,可能是父類的存在上面,因此先找到的父類的成員變量。然后測試了一下,代碼如下:
package test;public class Polymorphism { public static void main(String[] args) {F f = new Z();f.show();System.out.println('f:'+f);System.out.println('f:'+f.a); }}abstract class F{ int a = 10; public abstract void show();}class Z extends F{ int a = 5; public void show(){System.out.println('Z:'+this);System.out.println('Z:'+this.a); }}
輸出為:Z:test.Z@15db9742Z:5f:test.Z@15db9742f:10
f與this指向同一個對象訪問同一個變量結(jié)果卻不同,所以我上邊的猜測應(yīng)該是錯的。那究竟是什么原因?qū)е露鄳B(tài)調(diào)用同名成員變量,訪問的是父類的成員變量這種情況?
問題解答
回答1:f指的是子類對象。只聽過方法的重寫和重載,沒有類變量的重寫和重載吧,我運(yùn)行的程序,它分情況了,如果是調(diào)用方法,就是實際所指的對象(這里實際對象是子類對象Z)的方法,如果是類變量同名了,就是生命對象的類變量值。
回答2:java中方法的重寫,重載與動態(tài)鏈接構(gòu)成多態(tài),多態(tài)就是同一個事物的不同表現(xiàn)形式。
你這個例子是方法的重寫表現(xiàn)出來的多態(tài)性。
聲明的是父類F,實際上指向他的子類Z,這個時候是相當(dāng)于一個向上類型轉(zhuǎn)換,因為Z也是由F繼承過來的,所以可以向上轉(zhuǎn)型,現(xiàn)在Z是F類型的。
所以這里f變量由Z實例化出來的,但是它是F類型的,表現(xiàn)出來的是F的特性。
