Java面向对象---重写(Override)与重载(Overload)
一、重寫(Override)
重寫是子類對父類的允許訪問的方法的實現(xiàn)過程進行重新編寫, 返回值和形參都不能改變。即外殼不變,核心重寫!
重寫的好處在于子類可以根據(jù)需要,定義特定于自己的行為。 也就是說子類能夠根據(jù)需要實現(xiàn)父類的方法。
重寫方法不能拋出新的檢查異常或者比被重寫方法申明更加寬泛的異常。例如: 父類的一個方法申明了一個檢查異常 IOException,但是在重寫這個方法的時候不能拋出 Exception 異常,因為 Exception 是 IOException 的父類,只能拋出 IOException 的子類異常。
在面向?qū)ο笤瓌t里,重寫意味著可以重寫任何現(xiàn)有方法。實例如下:
1 class Animal{ 2 public void move(){ 3 System.out.println("動物可以移動"); 4 } 5 } 6 7 class Dog extends Animal{ 8 public void move(){ 9 System.out.println("狗可以跑和走"); 10 } 11 } 12 13 public class TestDog{ 14 public static void main(String args[]){ 15 Animal a = new Animal(); // Animal 對象 16 Animal b = new Dog(); // Dog 對象 17 18 a.move();// 執(zhí)行 Animal 類的方法 19 20 b.move();//執(zhí)行 Dog 類的方法 21 } 22 }以上實例編譯運行結(jié)果如下:
動物可以移動 狗可以跑和走在上面的例子中可以看到,盡管b屬于Animal類型,但是它運行的是Dog類的move方法。
這是由于在編譯階段,只是檢查參數(shù)的引用類型。
然而在運行時,Java虛擬機(JVM)指定對象的類型并且運行該對象的方法。
因此在上面的例子中,之所以能編譯成功,是因為Animal類中存在move方法,然而運行時,運行的是特定對象的方法。
思考以下例子:
1 class Animal{ 2 public void move(){ 3 System.out.println("動物可以移動"); 4 } 5 } 6 7 class Dog extends Animal{ 8 public void move(){ 9 System.out.println("狗可以跑和走"); 10 } 11 public void bark(){ 12 System.out.println("狗可以吠叫"); 13 } 14 } 15 16 public class TestDog{ 17 public static void main(String args[]){ 18 Animal a = new Animal(); // Animal 對象 19 Animal b = new Dog(); // Dog 對象 20 21 a.move();// 執(zhí)行 Animal 類的方法 22 b.move();//執(zhí)行 Dog 類的方法 23 b.bark(); 24 } 25 }以上實例編譯運行結(jié)果如下:
TestDog.java:30: cannot find symbol symbol : method bark() location: class Animal b.bark(); ^
該程序?qū)伋鲆粋€編譯錯誤,因為b的引用類型Animal沒有bark方法。
方法的重寫規(guī)則
-
參數(shù)列表必須完全與被重寫方法的相同;
-
返回類型必須完全與被重寫方法的返回類型相同;
-
訪問權(quán)限不能比父類中被重寫的方法的訪問權(quán)限更低。例如:如果父類的一個方法被聲明為public,那么在子類中重寫該方法就不能聲明為protected。
-
父類的成員方法只能被它的子類重寫。
-
聲明為final的方法不能被重寫。
-
聲明為static的方法不能被重寫,但是能夠被再次聲明。
-
子類和父類在同一個包中,那么子類可以重寫父類所有方法,除了聲明為private和final的方法。
-
子類和父類不在同一個包中,那么子類只能夠重寫父類的聲明為public和protected的非final方法。
-
重寫的方法能夠拋出任何非強制異常,無論被重寫的方法是否拋出異常。但是,重寫的方法不能拋出新的強制性異常,或者比被重寫方法聲明的更廣泛的強制性異常,反之則可以。
-
構(gòu)造方法不能被重寫。
-
如果不能繼承一個方法,則不能重寫這個方法。
Super關(guān)鍵字的使用
當需要在子類中調(diào)用父類的被重寫方法時,要使用super關(guān)鍵字。
1 class Animal{ 2 public void move(){ 3 System.out.println("動物可以移動"); 4 } 5 } 6 7 class Dog extends Animal{ 8 public void move(){ 9 super.move(); // 應(yīng)用super類的方法 10 System.out.println("狗可以跑和走"); 11 } 12 } 13 14 public class TestDog{ 15 public static void main(String args[]){ 16 17 Animal b = new Dog(); // Dog 對象 18 b.move(); //執(zhí)行 Dog類的方法 19 20 } 21 }以上實例編譯運行結(jié)果如下:
動物可以移動 狗可以跑和走二、重載(Overload)
重載(overloading) 是在一個類里面,方法名字相同,而參數(shù)不同。返回類型可以相同也可以不同。
每個重載的方法(或者構(gòu)造函數(shù))都必須有一個獨一無二的參數(shù)類型列表。
最常用的地方就是構(gòu)造器的重載。
重載規(guī)則
-
被重載的方法必須改變參數(shù)列表(參數(shù)個數(shù)或類型或順序不一樣);
-
被重載的方法可以改變返回類型;
-
被重載的方法可以改變訪問修飾符;
-
被重載的方法可以聲明新的或更廣的檢查異常;
-
方法能夠在同一個類中或者在一個子類中被重載。
-
無法以返回值類型作為重載函數(shù)的區(qū)分標準。
實例
1 public class Overloading { 2 public int test(){ 3 System.out.println("test1"); 4 return 1; 5 } 6 7 public void test(int a){ 8 System.out.println("test2"); 9 } 10 11 //以下兩個參數(shù)類型順序不同 12 public String test(int a,String s){ 13 System.out.println("test3"); 14 return "returntest3"; 15 } 16 17 public String test(String s,int a){ 18 System.out.println("test4"); 19 return "returntest4"; 20 } 21 22 public static void main(String[] args){ 23 Overloading o = new Overloading(); 24 System.out.println(o.test()); 25 o.test(1); 26 System.out.println(o.test(1,"test3")); 27 System.out.println(o.test("test4",1)); 28 } 29 }三、重寫與重載之間的區(qū)別
| 參數(shù)列表 | 必須修改 | 一定不能修改 |
| 返回類型 | 可以修改 | 一定不能修改 |
| 異常 | 可以修改 | 可以減少或刪除,一定不能拋出新的或者更廣的異常 |
| 訪問 | 可以修改 | 一定不能做更嚴格的限制(可以降低限制) |
總結(jié)
方法的重寫(Overriding)和重載(Overloading)是java多態(tài)性的不同表現(xiàn),重寫是父類與子類之間多態(tài)性的一種表現(xiàn),重載可以理解成多態(tài)的具體表現(xiàn)形式。
-
(1)方法重載是一個類中定義了多個方法名相同,而他們的參數(shù)的數(shù)量不同或數(shù)量相同而類型和次序不同,則稱為方法的重載(Overloading)。
-
(2)方法重寫是在子類存在方法與父類的方法的名字相同,而且參數(shù)的個數(shù)與類型一樣,返回值也一樣的方法,就稱為重寫(Overriding)。
-
(3)方法重載是一個類的多態(tài)性表現(xiàn),而方法重寫是子類與父類的一種多態(tài)性表現(xiàn)。
?
轉(zhuǎn)載于:https://www.cnblogs.com/zq-boke/p/8581877.html
總結(jié)
以上是生活随笔為你收集整理的Java面向对象---重写(Override)与重载(Overload)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 当深度学习遇上量化交易——模型篇
- 下一篇: ClassPathResource使用简