原文位址: http://www.work100.net/training/java-override-overload.html 更多教程: 光束雲 - 免費課程
重寫與重載
序号 | 文内章節 | 視訊 |
---|---|---|
1 | 重寫(Override) ) | - |
2 | 重載(Overload) | |
3 | 重寫與重載的差別 | |
4 | 總結 |
請參照如上
章節導航
進行閱讀
1.重寫(Override)
重寫是子類對父類的允許通路的方法的實作過程進行重新編寫, 傳回值和形參都不能改變。即外殼不變,核心重寫!
重寫的好處在于子類可以根據需要,定義特定于自己的行為。 也就是說子類能夠根據需要實作父類的方法。
重寫方法不能抛出新的檢查異常或者比被重寫方法申明更加寬泛的異常。例如: 父類的一個方法申明了一個檢查異常
IOException
,但是在重寫這個方法的時候不能抛出
Exception
異常,因為
Exception
是
IOException
的父類,隻能抛出
IOException
的子類異常。
在面向對象原則裡,重寫意味着可以重寫任何現有方法。執行個體如下:
class Animal{
public void move(){
System.out.println("動物可以移動");
}
}
class Dog extends Animal{
public void move(){
System.out.println("狗可以跑和走");
}
}
public class TestDog{
public static void main(String[] args){
Animal a = new Animal(); // Animal 對象
Animal b = new Dog(); // Dog 對象
a.move();// 執行 Animal 類的方法
b.move();//執行 Dog 類的方法
}
}
以上執行個體編譯運作結果如下:
動物可以移動
狗可以跑和走
在上面的例子中可以看到,盡管
b
屬于
Animal
類型,但是它運作的是
Dog
類的
move()
方法。
這是由于在編譯階段,隻是檢查參數的引用類型。
然而在運作時,Java 虛拟機(JVM)指定對象的類型并且運作該對象的方法。
是以在上面的例子中,之是以能編譯成功,是因為
Animal
類中存在
move()
方法,然而運作時,運作的是特定對象的方法。
思考以下例子:
class Animal{
public void move(){
System.out.println("動物可以移動");
}
}
class Dog extends Animal{
public void move(){
System.out.println("狗可以跑和走");
}
public void bark(){
System.out.println("狗可以吠叫");
}
}
public class TestDog{
public static void main(String[] args){
Animal a = new Animal(); // Animal 對象
Animal b = new Dog(); // Dog 對象
a.move();// 執行 Animal 類的方法
b.move();//執行 Dog 類的方法
b.bark();
}
}
TestDog.java:30: cannot find symbol
symbol : method bark()
location: class Animal
b.bark();
^
該程式将抛出一個編譯錯誤,因為b的引用類型
Animal
沒有
bark
方法的重寫規則
- 參數清單必須完全與被重寫方法的相同。
- 傳回類型與被重寫方法的傳回類型可以不相同,但是必須是父類傳回值的派生類(java5 及更早版本傳回類型要一樣,java7 及更高版本可以不同)。
- 通路權限不能比父類中被重寫的方法的通路權限更低。例如:如果父類的一個方法被聲明為
,那麼在子類中重寫該方法就不能聲明為public
。protected
- 父類的成員方法隻能被它的子類重寫。
- 聲明為
的方法不能被重寫。final
-
的方法不能被重寫,但是能夠被再次聲明。static
- 子類和父類在同一個包中,那麼子類可以重寫父類所有方法,除了聲明為
和private
的方法。final
- 子類和父類不在同一個包中,那麼子類隻能夠重寫父類的聲明為
public
的非protected
final
- 重寫的方法能夠抛出任何非強制異常,無論被重寫的方法是否抛出異常。但是,重寫的方法不能抛出新的強制性異常,或者比被重寫方法聲明的更廣泛的強制性異常,反之則可以。
- 構造方法不能被重寫。
- 如果不能繼承一個方法,則不能重寫這個方法。
Super關鍵字的使用
當需要在子類中調用父類的被重寫方法時,要使用
super
關鍵字。
class Animal{
public void move(){
System.out.println("動物可以移動");
}
}
class Dog extends Animal{
public void move(){
super.move(); // 應用super類的方法
System.out.println("狗可以跑和走");
}
}
public class TestDog{
public static void main(String[] args){
Animal b = new Dog(); // Dog 對象
b.move(); //執行 Dog類的方法
}
}
動物可以移動
狗可以跑和走
2.重載(Overload)
重載(
overloading
) 是在一個類裡面,方法名字相同,而參數不同。傳回類型可以相同也可以不同。
每個重載的方法(或者構造函數)都必須有一個獨一無二的參數類型清單。
最常用的地方就是構造器的重載。
重載規則
- 被重載的方法必須改變參數清單(參數個數或類型不一樣)
- 被重載的方法可以改變傳回類型
- 被重載的方法可以改變通路修飾
- 被重載的方法可以聲明新的或更廣的檢查異常
- 方法能夠在同一個類中或者在一個子類中被重載
- 無法以傳回值類型作為重載函數的區分标準
執行個體:
public class Overloading {
public int test(){
System.out.println("test1");
return 1;
}
public void test(int a){
System.out.println("test2");
}
//以下兩個參數類型順序不同
public String test(int a,String s){
System.out.println("test3");
return "returntest3";
}
public String test(String s,int a){
System.out.println("test4");
return "returntest4";
}
public static void main(String[] args){
Overloading o = new Overloading();
System.out.println(o.test());
o.test(1);
System.out.println(o.test(1,"test3"));
System.out.println(o.test("test4",1));
}
}
3.重寫與重載的差別
差別點 | 重載方法 | 重寫方法 |
---|---|---|
參數清單 | 必須修改 | 一定不能修改 |
傳回類型 | 可以修改 | |
異常 | 可以減少或删除,一定不能抛出新的或者更廣的異常 | |
通路 | 一定不能做更嚴格的限制(可以降低限制) |
4.總結
方法的重寫(
Overriding
)和重載(
Overloading
)是java多态性的不同表現,重寫是父類與子類之間多态性的一種表現,重載可以了解成多态的具體表現形式。
- 方法重載是一個類中定義了多個方法名相同,而他們的參數的數量不同或數量相同而類型和次序不同,則稱為方法的重載(
Overloading
- 方法重寫是在子類存在方法與父類的方法的名字相同,而且參數的個數與類型一樣,傳回值也一樣的方法,就稱為重寫(
Overriding
- 方法重載是一個類的多态性表現,而方法重寫是子類與父類的一種多态性表現

上一篇:
繼承下一篇:
多态如果對課程内容感興趣,可以掃碼關注我們的或
公衆号
,及時關注我們的課程更新
QQ群