Java靜態(tài)方法不具有多態(tài)性詳解
動態(tài)綁定機制使得基類的引用能夠指向正確的子類對象,從而使得面向基類編程成為可能。
然而動態(tài)綁定在以下兩種情況會失效。
1、基類方法是private或final修飾的
這個很好理解,因為private說明該方法對子類是不可見的,子類再寫一個同名的方法并不是對父類方法進行復(fù)寫(Override),而是重新生成一個新的方法,也就不存在多態(tài)的問題了。同理也可以解釋final,因為方法同樣是不可覆蓋的。
2、方法是static修飾的
代碼如下所示.
class Base { public static void staticMethod() { System.out.println("Base staticMehtod"); } public void dynamicMehtod() { System.out.println("Base dynamicMehtod"); } } class Sub extends Base { public static void staticMethod() { System.out.println("Sub staticMehtod"); } public void dynamicMehtod() { System.out.println("Sub dynamicMehtod"); } } public class TJ4 { public static void main(String args[]) { Base c = new Sub(); c.staticMethod(); c.dynamicMehtod(); } }/* OutPut: Base staticMehtod Sub dynamicMehtod */
輸出結(jié)果并不像設(shè)想的那樣,輸出 "Sub staticMehtod"。因為靜態(tài)方法是與類而不是與某個對象相關(guān)聯(lián),c.staticMethod();等同于Car.staticMethod(); 所以盡量不要使用實例變量去調(diào)用靜態(tài)方法,避免混淆。
以上這篇Java靜態(tài)方法不具有多態(tài)性詳解就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
- Java基礎(chǔ)教程之構(gòu)造器與方法重載
- Java構(gòu)造器使用方法及注意事項
- Java私有構(gòu)造器使用方法示例
- 實例解析Java中的構(gòu)造器初始化
- Java 7菱形語法與泛型構(gòu)造器實例分析
- Java Lambda表達式的方法引用和構(gòu)造器引用實例分析
- java用接口、多態(tài)、繼承、類計算三角形和矩形周長及面積的方法
- Java多態(tài)和實現(xiàn)接口的類的對象賦值給接口引用的方法(推薦)
- java 將方法作為傳參--多態(tài)的實例
- 基于Java中對域和靜態(tài)方法的訪問不具有多態(tài)性(實例講解)
- Java基礎(chǔ)之方法重寫和多態(tài)示例
- Java中構(gòu)造器內(nèi)部的多態(tài)方法的行為實例分析
相關(guān)文章
SpringMVC學(xué)習(xí)之JSON和全局異常處理詳解
在項目上線之后,往往會出現(xiàn)一些不可預(yù)料的異常信息,對于邏輯性或設(shè)計性問題,開發(fā)人員或者維護人員需要通過日志,查看異常信息并排除異常,這篇文章主要給大家介紹了關(guān)于SpringMVC學(xué)習(xí)之JSON和全局異常處理的相關(guān)資料,需要的朋友可以參考下2022-10-10UrlDecoder和UrlEncoder使用詳解_動力節(jié)點Java學(xué)院整理
這篇文章主要為大家詳細介紹了UrlDecoder和UrlEncoder使用方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07SpringBoot集成Redis實現(xiàn)驗證碼的簡單案例
本文主要介紹了SpringBoot集成Redis實現(xiàn)驗證碼的簡單案例,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-08-08