<dfn id="w48us"></dfn><ul id="w48us"></ul>
  • <ul id="w48us"></ul>
  • <del id="w48us"></del>
    <ul id="w48us"></ul>
  • Java方法繼承、重載和覆蓋總結

    時間:2024-05-09 03:30:52 SUN認證 我要投稿
    • 相關推薦

    Java方法繼承、重載和覆蓋總結

      Java 平臺是基于 Java 語言的平臺。這樣的平臺非常流行。因此微軟公司推出了與之競爭的.NET平臺以及模仿Java的C#語言。下面文章介紹了Java方法繼承、重載、覆蓋總結:

    Java方法繼承、重載和覆蓋總結

      1、方法繼承:

      利用extends關鍵字一個方法繼承另一個方法,而且只能直接繼承一個類。

      * 當Sub類和Base類在同一個包時Sub類繼承Base類中的public/protected/默認級別的變量個方法

      * 在不同包時繼承public/protected級別的變量和方法。

      2、方法重載:

      如果有兩個方法的方法名相同,但參數不一致,哪么可以說一個方法是另一個方法的重載。

      * 方法名相同

      * 方法的參數類型,個數順序至少有一項不同

      * 方法的返回類型可以不相同

      * 方法的修飾符可以不相同

      * main方法也可以被重載

      3、方法覆蓋:

      如果在子類中定義一個方法,其名稱、返回類型及參數簽名正好與父類中某個方法的名稱、返回類型及參數簽名相匹配,那么可以說,子類的方法覆蓋了父類的方法。

      * 子類的方法名稱返回類型及參數簽名 必須與父類的一致

      * 子類方法不能縮小父類方法的訪問權限

      * 子類方法不能拋出比父類方法更多的異常

      * 方法覆蓋只存在于子類和父類之間,同一個類中只能重載

      * 父類的靜態方法不能被子類覆蓋為非靜態方法

      * 子類可以定義于父類的靜態方法同名的靜態方法,以便在子類中隱藏父類的靜態方法(滿足覆蓋約束), 而且Java虛擬機把靜態方法和所屬的類綁定,而把實例方法和所屬的實例綁定。

      * 父類的非靜態方法不能被子類覆蓋為靜態方法

      * 父類的私有方法不能被子類覆蓋

      * 父類的抽象方法可以被子類通過兩種途徑覆蓋(即實現和覆蓋)(P169)

      * 父類的非抽象方法可以被覆蓋為抽象方法

      4、Super關鍵字:

      super和this關鍵字都可以用來覆蓋Java語言的默認作用域,使被屏蔽的方法或變量變為可見(三種情況下的不可見 P171)。

      * 父類的成員變量和方法為private使用super訪問編譯出錯

      * 在類的構造方法種,通過super語句調用這個類的父類的構造方法

      * 在子類種訪問父類的被屏蔽的方法和屬性

      * 只能在構造方法或實例方法內使用super關鍵字,而在靜態方法和靜態代碼塊內不能使用super

      5、多態:

      * 對于一個引用類型的變量,Java編譯器按照它的聲明的類型來處理

      * 對于一個引用類型的變量,運行時Java虛擬機按照它的實際引用的對象來處理

      * 運行時環境中,通過引用類型變量來訪問所引用對象的方法和屬性時,Java虛擬機采用以下綁定規則

      1)實例方法與引用變量實際引用的對象的方法綁定,屬于動態綁定

      2)靜態方法與引用變量所聲明的類型的方法綁定,屬于靜態綁定

      3)成員變量(包括靜態和實例變量)與引用變量所聲明的類型的成員變量綁定,屬于靜態綁定

      Java代碼

      class Super {

      static int stat = 1;

      int nonStat = 2;

      static int statMethod(){

      return 3;

      }

      int nonStatMethod(){

      return 4;

      }

      }

      public class Sub extends Super {

      static int stat = 10;

      int nonStat = 20;

      static int statMethod(){

      return 30;

      }

      int nonStatMethod(){

      return 40;

      }

      public static void main(String args) {

      Super s = new Sub();

      System.out.println("Static is " + s.stat);

      System.out.println("Non-Static is " + s.nonStat);

      System.out.println("Static method is " + s.statMethod() );

      System.out.println("Non-Static method is " + s.nonStatMethod() );

      Sub sub = (Sub)s;

      System.out.println("Static is " + sub.stat);

      System.out.println("Non-Static is " + sub.nonStat);

      System.out.println("Static method is " + sub.statMethod() );

      System.out.println("Non-Static method is " + sub.nonStatMethod() );

      }

      }

      輸出結果:

      Static is 1

      Non-Static is 2

      Static method is 3

      Non-Static method is 40

      Static is 10

      Non-Static is 20

      Static method is 30

      Non-Static method is 40

    【Java方法繼承、重載和覆蓋總結】相關文章:

    Java方法(函數)傳值和傳引用的問題03-17

    Java枚舉的常用方法03-16

    Java線程同步的方法03-17

    Java中日期的處理方法03-09

    JAVA認證開源技術:關于Java的對象equals方法03-04

    Java數組操作方法大全03-04

    Java獲取當前的系統時間的方法03-04

    Java開發Tomcat部署項目方法03-04

    Java動態代理實現AOP的方法03-16

    主站蜘蛛池模板: 亚洲一区精品无码| 精品性影院一区二区三区内射| 日韩蜜芽精品视频在线观看| 国产乱码精品一品二品| 久久久久亚洲精品男人的天堂| 国产精品国产三级专区第1集| 影院无码人妻精品一区二区| 四虎国产精品免费入口| 精品性影院一区二区三区内射| 欧美精品亚洲人成在线观看| 91午夜精品亚洲一区二区三区| 国产精品无码久久久久久| 区亚洲欧美一级久久精品亚洲精品成人网久久久久 | 国产精品成人A区在线观看| 青春草无码精品视频在线观| 亚洲国产精品婷婷久久| 国产精品女同一区二区| 亚洲av午夜福利精品一区 | 亚洲国产成人久久精品动漫 | 精品精品国产高清a毛片牛牛| 日本VA欧美VA欧美VA精品| 四虎国产精品成人| 精品国产婷婷久久久| www亚洲欲色成人久久精品| 精品无人区麻豆乱码1区2区 | 久久精品成人免费网站| 国产精品特级毛片一区二区三区| 熟妇人妻VA精品中文字幕| 亚洲精品视频免费观看| 亚洲国产精品无码久久九九| 免费人妻精品一区二区三区| 国产一在线精品一区在线观看 | 久久国产精品一国产精品金尊| 亚洲综合国产精品第一页 | 亚洲av无码成人精品国产| 免费人欧美日韩在线精品| 久久精品国产精品亜洲毛片| 国内精品久久久久久久涩爱| 国产精品人人做人人爽| 国产亚洲精品无码专区| 精品多毛少妇人妻AV免费久久|