如何實現(xiàn)多態(tài) JAVA中的多態(tài)與重載有什么區(qū)別?
JAVA中的多態(tài)與重載有什么區(qū)別?它們之間的區(qū)別如下:多態(tài)性基于重寫。它是類之間的關(guān)系,發(fā)生在不同的類之間。子類重寫父類的方法。實現(xiàn)不同的子類,不同的實現(xiàn)形式。多態(tài)性有三個條件1:繼承2:重寫(重寫父
JAVA中的多態(tài)與重載有什么區(qū)別?
它們之間的區(qū)別如下:
多態(tài)性基于重寫。它是類之間的關(guān)系,發(fā)生在不同的類之間。子類重寫父類的方法。實現(xiàn)不同的子類,不同的實現(xiàn)形式。
多態(tài)性有三個條件
1:繼承
2:重寫(重寫父類繼承的方法)
3:父類引用指向子類對象
總之,事物在運行過程中有不同的狀態(tài)。
Super*P=new sub()
P->func()//調(diào)用子類的func
如果它不是虛的,P->func將調(diào)用父類的原始函數(shù)。
JAVA的多態(tài)用幾句話能直觀的解釋一下嗎?
多態(tài)性分為編譯時多態(tài)性和運行時多態(tài)性。
1. 編譯時多態(tài)性,其實是方法重載,函數(shù)名相同,但簽名不一樣。值得注意的是,簽名不包括方法的返回值。換句話說,這兩個方法的函數(shù)名和輸入?yún)?shù)是相同的,但返回值不同。編譯器返回錯誤。
2. 運行時多態(tài)性實際上與繼承和接口實現(xiàn)有關(guān)。子類可以重寫父類的非最終、非靜態(tài)、非私有方法或?qū)崿F(xiàn)接口方法。JVM如何知道要調(diào)用哪個子類實例的對應(yīng)方法?這就是你問的問題。在Java中,對象在JVM中有描述元數(shù)據(jù)。對象頭存儲當(dāng)前實例的類型信息。在調(diào)用時,JVM可以根據(jù)這個類型準(zhǔn)確地找出要使用的子類方法。