推 snowlike: 先不論怎麼理解,第二個和第三個如果不同實際上更奇怪04/14 14:06
→ snowlike: name 實際上有兩個只是 son 裡的 name 產生了遮蔽的效果04/14 14:07
所以我不懂的是,son 裡的 name 產生了遮蔽的效果,那為什麼結果不是Son,而是Fathe
r呢?
因為我理解不過來,所以不懂哪裡奇怪
→ bitlife: docs.oracle.com/javase/specs/jls/se7/html/jls-4.html04/14 14:14
→ bitlife: The Java programming language is a statically typed04/14 14:14
→ bitlife: language, which means that every variable and every04/14 14:14
→ bitlife: expression has a type that is known at compile time.04/14 14:14
意思是說在編譯時期型態為Father
但之後實際執行的不是Son嗎?
※ 編輯: birdy1147 (111.70.24.157), 04/14/2016 14:38:04
推 snowlike: 因為你看的是 Fa 的 name,會提遮蔽就是因為非繼承關係04/14 14:51
→ snowlike: 樓上是 Fa 和 So 的變數都存在的意思不用再往繼承思考04/14 14:56
抱歉...我還是沒有懂
greeting因為覆寫所以是class Son
那麼Son的name不是也遮蔽了father的name嗎?
那第二個為什麼不是Son?
※ 編輯: birdy1147 (111.70.24.157), 04/14/2016 15:10:45
→ bitlife: 不是告訴你在compile time就確定型別了嗎? 04/14 15:58
→ bitlife: ^variable 04/14 15:59
→ ntuarthur: virtual method table 04/14 16:07
→ bitlife: 多型和確定型本身就是相反的概念,多型是在執行時期為了確 04/14 22:14
→ bitlife: 定要使用那個method,所以需要確定執行時期的型別,而field 04/14 22:15
→ bitlife: 的存取,在編譯時期就決定了要存取哪個型別的某個field 04/14 22:16
→ bitlife: 要存取name,所以fa在編譯時期就確定了它是Father型別 04/14 22:17
→ bitlife: 那個fa = new Son(); 是人類望文生義理解它實際會是Son, 04/14 22:18
→ bitlife: 但compile time沒有這個資訊(別期待編譯器像人一樣「懂」 04/14 22:19
→ bitlife: ),如果你是寫 Father fa = someFunction() 呢,不把整個程 04/14 22:19
→ bitlife: 式實際跑一遍是不可能在compile time知道的.總之,多型是 04/14 22:20
→ bitlife: 到run time再查真實型別以執行對應該執行的method 04/14 22:21
→ bitlife: 實務則用virtual function/method table來做,把問題提早 04/14 22:22
→ bitlife: 到編譯時期即可解決,但field不能這樣幹,因為field如前面 04/14 22:22
→ bitlife: 所說,不是pure virtual,只是被子代遮掉,實際上有兩份, 04/14 22:23
→ bitlife: pure virtual function在virtual function/method table 04/14 22:23
→ bitlife: 中,子代的method會蓋掉親代的method 04/14 22:24
→ bitlife: 更正,上面的pure都去掉,和pure與否無關(C++的virutal在 04/14 22:27
→ bitlife: Java是預設,而C++的pure virtaul變成了Java的virutal,我 04/14 22:28
→ bitlife: 寫的時候一直想著C++的實務,才多寫pure 04/14 22:28
推 bitlife: abstract XD 04/14 22:31
→ ntuarthur: 樓上乾脆回一篇比較好讀。或者就給他key word XD 04/15 15:41