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

