Java方法重載和方法重寫的區(qū)別到底在哪?
方法重載和方法重寫的區(qū)別
方法重載
方法重載的主要是在一個(gè)類當(dāng)中,方法的方法名相同,參數(shù)列表不同,返回值類型可以相同,也可以不同.
/* 這里只是簡(jiǎn)單的示例一下,Food Snack沒有給出,意會(huì)一下即可. */ public class Demo{ public void eat(Food food){ System.out.println("今天正常吃飯!吃了" + food.name); } public void eat(Snack snack){ System.out.println("今天想吃零食!吃了" + snack.name); } public int eat(){ int money = 10; System.out.println("今天喝西北風(fēng)!但是省錢了,返回省錢的數(shù)目"); return 10; } //public void eat(){ // int money = 10; // System.out.println("今天喝西北風(fēng)!但是省錢了,返回省錢的數(shù)目"); //} }
注意:如果參數(shù)列表相同,返回值類型不同是不算重載的.這種寫法會(huì)直接報(bào)錯(cuò).因?yàn)樵谡{(diào)用方法的時(shí)候,我們還不知道方法的返回值類型,所以編譯器無法區(qū)分你調(diào)用的是哪個(gè)方法,肯定就傻掉了,所以就告訴你,兄弟你寫錯(cuò)了!
方法重寫
方法的重寫體現(xiàn)在子父類當(dāng)中,最典型的是子類重寫父類中的方法.
Father類和Son類都有Walk(boolean canRun)方法.
但是執(zhí)行的時(shí)候結(jié)果卻不同.
public class Father { private boolean canRun = false; public boolean isCanRun() { return canRun; } public void setCanRun(boolean canRun) { this.canRun = canRun; } public void walk(boolean canRun){ if(canRun){ System.out.println("父親盡力跑啊跑!"); }else{ System.out.println("父親老了,只可以走路!"); } } }
public class Son extends Father{ boolean canRun; public Son(boolean canRun){ this.canRun = canRun; } @Override public void walk(boolean canRun) { if(canRun){ System.out.println("兒子可以跑!"); }else{ System.out.println("兒子也只能走!"); } } }
public class Test { public static void main(String[] args) { Father father = new Father(); Son son = new Son(true); father.walk(father.isCanRun()); son.walk(son.canRun); } }
這里體現(xiàn)的就是子類Son重寫了父類中的Walk()方法.
注意:重寫這里有一個(gè)重要的點(diǎn)在于子類重寫的方法不能低于父類方法的訪問權(quán)限.
可以簡(jiǎn)單理解一下:在多態(tài)當(dāng)中,父類引用指向子類對(duì)象,如果子類對(duì)象中重寫的方法權(quán)限低于父類方法了,那么多態(tài)情況下,父類引用就無法訪問子類中的方法了.
public class Test { public static void main(String[] args) { Father father = new Son(true); System.out.println(father.isCanRun()); // false father.walk(father.isCanRun()); // 兒子也只能走! } }
這里很神奇,明明我的Son對(duì)象創(chuàng)建的時(shí)候傳入的參數(shù)是true,為什么執(zhí)行結(jié)果卻是兒子也只能走!
呢?
這里先進(jìn)行一下這個(gè)知識(shí)點(diǎn)的小結(jié),上面的問題會(huì)在下一個(gè)文章中講解.
小結(jié)
1.方法重載體現(xiàn)在同一個(gè)類當(dāng)中同名方法參數(shù)列表不同的情況(必須滿足),返回值類型可以相同也可以不同.如果兩個(gè)方法方法名相同,參數(shù)列表相同但是返回值類型不同是不算重載的.
2.方法重寫體現(xiàn)在子父類當(dāng)中,體現(xiàn)的不同類之間的聯(lián)系.要求子類重寫的方法有和父類相同的方法名,參數(shù)列表和返回值類型,但是方法內(nèi)部的具體操作可以發(fā)生變化.方法重寫時(shí)要求子類方法的范文權(quán)限不能低于父類方法的訪問權(quán)限
到此這篇關(guān)于Java方法重載和方法重寫的區(qū)別到底在哪?的文章就介紹到這了,更多相關(guān)Java方法重載和方法重寫內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringCloud之微服務(wù)容錯(cuò)的實(shí)現(xiàn)
這篇文章主要介紹了SpringCloud之微服務(wù)容錯(cuò)的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05Java?@Scheduled定時(shí)任務(wù)不執(zhí)行解決辦法
這篇文章主要給大家介紹了關(guān)于Java?@Scheduled定時(shí)任務(wù)不執(zhí)行解決的相關(guān)資料,當(dāng)@Scheduled定時(shí)任務(wù)不執(zhí)行時(shí)可以根據(jù)以下步驟進(jìn)行排查和解決,需要的朋友可以參考下2023-10-10SpringBoot+slf4j線程池全鏈路調(diào)用日志跟蹤問題及解決思路(二)
本文主要給大家介紹如何實(shí)現(xiàn)子線程中的traceId日志跟蹤,本文通過封裝Callable為例給大家介紹的非常詳細(xì),需要的朋友一起看看吧2021-05-05SpringBoot項(xiàng)目引入第三方sdk?jar包的解決方案
這篇文章主要介紹了SpringBoot項(xiàng)目引入第三方sdk?jar包,個(gè)人感覺比較好的解決方案是將 jar上傳到本地的maven倉庫,然后通過pom依賴,引入第三方j(luò)ar包,需要的朋友可以參考下2022-05-05