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

