• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            chenglong7997

            java重寫方法的原則

             若想實現一個合格重寫方法,而不是重載,那么必須同時滿足下面的要求! 

            A、重寫規則之一:
                重寫方法不能比被重寫方法限制有更嚴格的訪問級別。 
            (但是可以更廣泛,比如父類方法是包訪問權限,子類的重寫方法是public訪問權限。) 比如:Object類有個toString()方法,開始重寫這個方法的時候我們總容易忘記public修飾符,編譯器當然不會放過任何教訓我們 的機會。出錯的原因就是:沒有加任何訪問修飾符的方法具有包訪問權限,包訪問權限比public當然要嚴格了,所以編譯器會報錯的。 

            B、重寫規則之二
               參數列表必須與被重寫方法的相同。 
            重寫有個孿生的弟弟叫重載,也就是后面要出場的。如果子類方法的參數與父類對應的方法不同,那么就是你認錯人了,那是重載,不是重寫。 

            C、重寫規則之三:
               返回類型必須與被重寫方法的返回類型相同。
            父類方法A:void eat(){} 子類方法B:int eat(){} 兩者雖然參數相同,可是返回類型不同,所以不是重寫。
            父類方法A:int eat(){} 子類方法B:long eat(){} 返回類型雖然兼容父類,但是不同就是不同,所以不是重寫。

            D、重寫規則之四:
               重寫方法不能拋出新的異常或者比被重寫方法聲明的檢查異常更廣的檢查異常。但是可以拋出更少,更有限或者不拋出異常。
            import java.io.*;
            public class Test {
              public static void main (String[] args) {
               Animal h = new Horse();
               try {
                 h.eat(); 
               }
               catch (Exception e) {
               }
             }
            }

            class Animal {
              public void eat() throws Exception{
               System.out.println ("Animal is eating.");
               throw new Exception();
              }
            }

            class Horse extends Animal{
               public void eat() throws IOException{
                System.out.println ("Horse is eating.");
                throw new IOException();
              }
            }

            這個例子中,父類拋出了檢查異常Exception,子類拋出的IOException是Exception的子類,也即是比被重寫的方法拋出了更有限的異常,這是可以的。如果反過來,父類拋出IOException,子類拋出更為寬泛的Exception,那么不會通過編譯的。
            注意:這種限制只是針對檢查異常,至于運行時異常RuntimeException及其子類不再這個限制之中。

            E、重寫規則之五:
               不能重寫被標識為final的方法。

            F、重寫規則之六:
              如果一個方法不能被繼承,則不能重寫它。
            比較典型的就是父類的private方法。下例會產生一個有趣的現象。
            public class Test {
              public static void main (String[] args) {
               //Animal h = new Horse();
               Horse h = new Horse();
                h.eat();
               }
            }

            class Animal {
               private void eat(){
                System.out.println ("Animal is eating.");
                }
             }

            class Horse extends Animal{
               public void eat(){
                 System.out.println ("Horse is eating.");
               }
            }
            這段代碼是能通過編譯的。表面上看來違反了第六條規則,但實際上那是一點巧合。Animal類的eat()方法不能被繼承,因此Horse類中的 eat()方法是一個全新的方法,不是重寫也不是重載,只是一個只屬于Horse類的全新的方法!這點讓很多人迷惑了,但是也不是那么難以理解。
            main()方法如果是這樣:
            Animal h = new Horse();
            //Horse h = new Horse();
            h.eat();
            編譯器會報錯,為什么呢?Horse類的eat()方法是public的啊!應該可以調用啊!請牢記,多態只看父類引用的方法,而不看子類對象的方法!

            posted on 2012-04-11 13:55 Snape 閱讀(4865) 評論(0)  編輯 收藏 引用 所屬分類: Java

            導航

            <2025年6月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            293012345

            統計

            常用鏈接

            留言簿

            隨筆分類

            隨筆檔案

            文章分類

            文章檔案

            my

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            91秦先生久久久久久久| 婷婷五月深深久久精品| 青草影院天堂男人久久| 国产一级持黄大片99久久| 久久国产精品二国产精品| 四虎影视久久久免费| 久久只有这精品99| 久久久无码精品亚洲日韩蜜臀浪潮| …久久精品99久久香蕉国产| 久久无码AV中文出轨人妻| A狠狠久久蜜臀婷色中文网| 无码国内精品久久人妻麻豆按摩| 亚洲色欲久久久久综合网| 久久久综合九色合综国产| 久久综合久久伊人| 久久66热人妻偷产精品9| 国产精品久久久99| 久久电影网一区| 伊人久久大香线蕉无码麻豆 | 久久国产影院| 久久99国产乱子伦精品免费| 久久久久亚洲精品天堂久久久久久| 亚洲精品无码成人片久久| 久久久久久A亚洲欧洲AV冫| 精品久久久久久成人AV| 久久久午夜精品福利内容| 精品无码久久久久久国产| 国产69精品久久久久777| 久久天天躁夜夜躁狠狠躁2022| 久久高潮一级毛片免费| 国产精品一久久香蕉国产线看观看| 亚洲精品高清一二区久久| 国产精品九九久久精品女同亚洲欧美日韩综合区 | 精品亚洲综合久久中文字幕| 狠狠综合久久AV一区二区三区| 亚洲日韩欧美一区久久久久我| 亚洲国产精品久久久久婷婷老年| 久久久久99精品成人片试看| 精品国产乱码久久久久久人妻| 久久人做人爽一区二区三区| 色诱久久av|