<em id="0a85b"><option id="0a85b"></option></em>

<abbr id="0a85b"></abbr>

      <nobr id="0a85b"></nobr>
        <tr id="0a85b"></tr>
        9久久伊人精品综合,亚洲一区精品视频在线,成 人免费va视频,国产一区二区三区黄网,99国产精品永久免费视频,亚洲毛片多多影院,精品久久久无码人妻中文字幕,无码国产欧美一区二区三区不卡
        學習啦>生活課堂>生活小常識>

        java中重寫和重載的區別

        時間: 志峰887 分享

          下面是學習啦小編為大家準備的java中重寫和重載的區別,希望大家喜歡!

          首先我們來講講:重載(Overloading)

          (1) 方法重載是讓類以統一的方式處理不同類型數據的一種手段。多個同名函數同時存在,具有不同的參數個數/類型。

          重載Overloading是一個類中多態性的一種表現。

          (2) Java的方法重載,就是在類中可以創建多個方法,它們具有相同的名字,但具有不同的參數和不同的定義。

          調用方法時通過傳遞給它們的不同參數個數和參數類型來決定具體使用哪個方法, 這就是多態性。

          (3) 重載的時候,方法名要一樣,但是參數類型和個數不一樣,返回值類型可以相同也可以不相同。無法以返回型別作為重載函數的區分標準。

          下面是重載的例子:

          package c04.answer;//這是包名

          //這是這個程序的第一種編程方法,在main方法中先創建一個Dog類實例,然后在Dog類的構造方法中利用this關鍵字調用不同的bark方法。

          不同的重載方法bark是根據其參數類型的不同而區分的。

          //注意:除構造器以外,編譯器禁止在其他任何地方中調用構造器。

          package c04.answer;

          public class Dog {

          Dog()

          {

          this.bark();

          }

          void bark()//bark()方法是重載方法

          {

          System.out.println(\"no barking!\");

          this.bark(\"female\", 3.4);

          }

          void bark(String m,double l)//注意:重載的方法的返回值都是一樣的,

          {

          System.out.println(\"a barking dog!\");

          this.bark(5, \"China\");

          }

          void bark(int a,String n)//不能以返回值區分重載方法,而只能以“參數類型”和“類名”來區分

          {

          System.out.println(\"a howling dog\");

          }

          public static void main(String[] args)

          {

          Dog dog = new Dog();

          //dog.bark(); [Page]

          //dog.bark(\"male\", \"yellow\");

          //dog.bark(5, \"China\");

          然后我們再來談談 重寫(Overriding)

          (1) 父類與子類之間的多態性,對父類的函數進行重新定義。如果在子類中定義某方法與其父類有相同的名稱和參數,我們說該方法被重寫 (Overriding)。在Java中,子類可繼承父類中的方法,而不需要重新編寫相同的方法。

          但有時子類并不想原封不動地繼承父類的方法,而是想作一定的修改,這就需要采用方法的重寫。

          方法重寫又稱方法覆蓋。

          (2)若子類中的方法與父類中的某一方法具有相同的方法名、返回類型和參數表,則新方法將覆蓋原有的方法。

          如需父類中原有的方法,可使用super關鍵字,該關鍵字引用了當前類的父類。

          (3)子類函數的訪問修飾權限不能少于父類的;

          下面是重寫的例子:

          概念:即調用對象方法的機制。

          動態綁定的內幕:

          1、編譯器檢查對象聲明的類型和方法名,從而獲取所有候選方法。試著把上例Base類的test注釋掉,這時再編譯就無法通過。

          2、重載決策:編譯器檢查方法調用的參數類型,從上述候選方法選出唯一的那一個(其間會有隱含類型轉化)。

          如果編譯器找到多于一個或者沒找到,此時編譯器就會報錯。試著把上例Base類的test(byte b)注釋掉,這時運行結果是1 1。

          3、若方法類型為priavte static final ,java采用靜態編譯,編譯器會準確知道該調用哪

          個方法。

          4、當程序運行并且使用動態綁定來調用一個方法時,那么虛擬機必須調用對象的實際類型相匹配的方法版本。

          在例子中,b所指向的實際類型是TestOverriding,所以b.test(0)調用子類的test。

          但是,子類并沒有重寫test(byte b),所以b.test((byte)0)調用的是父類的test(byte b)。

          如果把父類的(byte b)注釋掉,則通過第二步隱含類型轉化為int,最終調用的是子類的test(int i)。

          學習總結

          多態性是面向對象編程的一種特性,和方法無關,

          簡單說,就是同樣的一個方法能夠根據輸入數據的不同,做出不同的處理,即方法的

          重載——有不同的參數列表(靜態多態性)

          而當子類繼承自父類的相同方法,輸入數據一樣,但要做出有別于父類的響應時,你就要覆蓋父類方法,

          即在子類中重寫該方法——相同參數,不同實現(動態多態性)

          OOP三大特性:繼承,多態,封裝。

          public class Base

          {

          void test(int i)

          {

          System.out.print(i);

          }

          void test(byte b)

          {

          System.out.print(b);

          }

          }

          public class TestOverriding extends Base

          {

          void test(int i)

          {

          i++;

          System.out.println(i);

          }

          public static void main(String[]agrs)

          {

          Base b=new TestOverriding();

          b.test(0)

          b.test((byte)0)

          }

          }

          這時的輸出結果是1 0,這是運行時動態綁定的結果。

          重寫的主要優點是能夠定義某個子類特有的特征:

          public class Father{

          public void speak(){

          System.out.println(Father);

          }

          }

          public class Son extends Father{

          public void speak(){

          System.out.println("son");

          }

          }

          這也叫做多態性,重寫方法只能存在于具有繼承關系中,重寫方法只能重寫父類非私有的方法。

          當上例中Father類speak()方法被private時,Son類不能重寫出Father類speak()方法,此時Son類speak()方法相當與在Son類中定義的一個speak()方法。

          Father類speak()方法一但被final時,無論該方法被public,protected及默認所修飾時,Son類根本不能重寫Father類speak()方法,

          試圖編譯代碼時,編譯器會報錯。例:

          public class Father{

          final public void speak(){

          System.out.println("Father");

          }

          }

          public class Son extends Father{

          public void speak(){

          System.out.println("son");

          }

          } //編譯器會報錯;

          Father類speak()方法被默認修飾時,只能在同一包中,被其子類被重寫,如果不在同一包則不能重寫。

          Father類speak()方法被protoeted時,不僅在同一包中,被其子類被重寫,還可以不同包的子類重寫。

          重寫方法的規則:

          1、參數列表必須完全與被重寫的方法相同,否則不能稱其為重寫而是重載。

          2、返回的類型必須一直與被重寫的方法的返回類型相同,否則不能稱其為重寫而是重載。

          3、訪問修飾符的限制一定要大于被重寫方法的訪問修飾符(public>protected>default>private)

          4、重寫方法一定不能拋出新的檢查異常或者比被重寫方法申明更加寬泛的檢查型異常。例如:

          父類的一個方法申明了一個檢查異常IOException,在重寫這個方法是就不能拋出Exception,只能拋出IOException的子類異常,可以拋出非檢查異常。

          而重載的規則:

          1、必須具有不同的參數列表;

          2、可以有不責罵的返回類型,只要參數列表不同就可以了;

          3、可以有不同的訪問修飾符;

          4、可以拋出不同的異常;

          重寫與重載的區別在于:

          重寫多態性起作用,對調用被重載過的方法可以大大減少代碼的輸入量,同一個方法名只要往里面傳遞不同的參數就可以擁有不同的功能或返回值。

          用好重寫和重載可以設計一個結構清晰而簡潔的類,可以說重寫和重載在編寫代碼過程中的作用非同一般.

        1720203 主站蜘蛛池模板: a级黑人大硬长爽猛出猛进| 亚洲无人区码一二三区别| 欧美午夜一区| 国产美女免费永久无遮挡| 国产精品青青在线观看爽香蕉| 国产精品久久久久久久9999| 国产成人精品亚洲资源| 亚洲成人av在线资源网| 国产成人亚洲一区二区三区| 日韩欧美aⅴ综合网站发布| 国产精品人成视频免| 国产精品无码专区| 与子乱对白在线播放单亲国产| 黄色一级片免费观看| 亚洲日本韩国欧美云霸高清| 国产偷窥厕所一区二区| 国产视频深夜在线观看| 亚洲岛国av一区二区| 国产粉嫩美女一区二区三| 亚洲精品成人7777在线观看| 永久免费无码av在线网站| 欧美老少配性行为| 国产精品午夜性视频| 欧美和黑人xxxx猛交视频| 国产福利免费在线观看| 风韵丰满熟妇啪啪区老熟熟女| 亚洲色大成网站WWW永久麻豆 | 青青草无码免费一二三区| 国产偷国产偷高清精品| 国产久免费热视频在线观看| 亚洲国产综合亚洲综合国产| 午夜福利偷拍国语对白| 狠狠精品久久久无码中文字幕| 久久综合噜噜激激的五月天| 草裙社区精品视频播放| 国产高清在线精品二区| 婷婷久久综合九色综合88| 一级二级三一片内射视频在线| 亚洲精品第一区二区在线| 黄色三级亚洲男人的天堂| 人成午夜大片免费视频77777|