<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                合規國際互聯網加速 OSASE為企業客戶提供高速穩定SD-WAN國際加速解決方案。 廣告
                # Java 重寫(Override)與重載(Overload) ## 重寫(Override) 重寫是子類對父類的允許訪問的方法的實現過程進行重新編寫!返回值和形參都不能改變。即外殼不變,核心重寫! 重寫的好處在于子類可以根據需要,定義特定于自己的行為。 也就是說子類能夠根據需要實現父類的方法。 在面向對象原則里,重寫意味著可以重寫任何現有方法。實例如下: ``` 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方法。 ## 方寫重寫的規則 * 參數列表必須完全與被重寫方法的相同; * 返回類型必須完全與被重寫方法的返回類型相同; * 訪問權限不能比父類中被重寫的方法的訪問權限更高。例如:如果父類的一個方法被聲明為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(); / b.move(); //執行 Dog類的方法 } } ``` 以上實例編譯運行結果如下: ``` 動物可以移動 狗可以跑和走 ``` ## 重載(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)); } ``` ## 重寫與重載之間的區別 | 區別點 | 重載方法 | 重寫方法 | | --- | --- | --- | | 參數列表 | 必須修改 | 一定不能修改 | | 返回類型 | 可以修改 | 一定不能修改 | | 異常 | 可以修改 | 可以減少或刪除,一定不能拋出新的或者更廣的異常 | | 訪問 | 可以修改 | 一定不能做更嚴格的限制(可以降低限制) |
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看