1.怎樣判斷物件是否可以轉換?
可以使用instanceof運算子判斷乙個物件是否可以轉換為指定的型別。
例:
1程式執行結果:public
class
testinstanceof
220 }
2.現有三個類
class mammal{}
class dog extends mammal{}
class cat extends mammal{}
先對其分別進行初始化:
mammal m = null;
dog d = new dog();
cat c = new cat();
下列語句哪乙個將引起編譯錯誤?為什麼?哪乙個會引起執行時錯誤?為什麼?
m = d;
d = m;
d = (dog)m;
d = c;
c = (cat)m;
事先判斷結果:
出現編譯錯誤:第二行,原因:不能將父類變數賦值給子類變數。
第四行,原因:繼承於同乙個父類的兩個平行子類不能互相賦值。
出現執行錯誤:第五行,原因:在第一行中,m變數已經指向dog物件,如果再執行c = (cat)m,就是讓c指向dog物件,而cat和dog之間不存在繼承關係,無法讓c指向dog物件。
結論:物件之間互相賦值時,子類物件可以對父類物件賦值,父類物件不能對子類變數賦值,繼承與同一基類的平行子類之間不能相互賦值。
3.執行以下測試**:
1上邊的程式的執行結果是什麼?public
class
parentchildtest 18}
1920
class
parent25}
26class child extends
parent
31 }
總結:子類可以賦值給父類,代表父類變數引用子類的物件。子類可以覆蓋父類,覆蓋後引用的是子類的方法,如果需要引用父類的方法可以用super函式。當子類與父類擁有一樣的方法,並且讓乙個父類變數引用乙個子類物件時,到底呼叫哪個方法,由物件自己的「真實」型別所決定,這就是說:物件是子型別的,它就呼叫子型別的方法,是父型別的,它就呼叫父型別的方法。這個特性實際上就是物件導向「多型」特性的具體表現。如果子類與父類有相同的字段,子類方法中訪問的是子類中的字段(而不是父類中的字段)。如果子類方法確實想訪問父類中被隱藏的同名字段,可以用super關鍵字來訪問它。如果子類被當做父類使用,則通過子類訪問的字段是父類的。
動手動腦(繼承與多型)
1.為什麼子類的構造方法在執行之前,必須呼叫父類的構造方法?能不能反過來?為什麼不能反過來?構造方法主要用來建立物件時初始化物件,即為物件變數賦初始值。建立乙個物件,先呼叫構造方法來進行初始化,子類擁有父類的成員變數和方法,如果不調父類的構造方法,則從父類繼承而來的成員變數和方法得不到正確的初始化。...
繼承與多型 動手動腦
1.和測試結果如下 2.我的猜想 parent.printvalue myvalue 100 child.printvalue myvalue 200 parent.printvalue myvalue 101 child.printvalue myvalue 200 child.printvalu...
繼承與多型動手動腦總結
一 繼承條件下的構造方法呼叫 程式 class grandparent public grandparent string string class parent extends grandparent class child extends parent public class testinhe...