1) 方法重載是讓類以統(tǒng)一的方式處理不同類型數(shù)據(jù)的一種手段。多個(gè)同名函數(shù)同時(shí)存在,具有不同的參數(shù)個(gè)數(shù)/類型。重載Overloading是一個(gè)類中多態(tài)性的一種表現(xiàn)。
(2) Java的方法重載,就是在類中可以創(chuàng)建多個(gè)方法,它們具有相同的名字,但具有不同的參數(shù)和不同的定義。調(diào)用方法時(shí)通過傳遞給它們的不同參數(shù)個(gè)數(shù)和參數(shù)類型來決定具體使用哪個(gè)方法, 這就是多態(tài)性。 ?。?) 重載的時(shí)候,方法名要一樣,但是參數(shù)類型和個(gè)數(shù)不一樣,返回值類型可以相同也可以不相同。無法以返回型別作為重載函數(shù)的區(qū)分標(biāo)準(zhǔn)。 下面是重載的例子: package c04.answer;//這是包名 //這是這個(gè)程序的第一種編程方法,在main方法中先創(chuàng)建一個(gè)Dog類實(shí)例,然后在Dog類的構(gòu)造方法中利用this關(guān)鍵字調(diào)用不同的bark方法。不同的重載方法bark是根據(jù)其參數(shù)類型的不同而區(qū)分的。 //注意:除構(gòu)造器以外,編譯器禁止在其他任何地方中調(diào)用構(gòu)造器。 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)//不能以返回值區(qū)分重載方法,而只能以“參數(shù)類型”和“類名”來區(qū)分 { System.out.println(\"a howling dog\"); } public static void main(String[] args) { Dog dog = new Dog(); //dog.bark(); //dog.bark(\"male\", \"yellow\"); //dog.bark(5, \"China\"); 然后我們?cè)賮碚務(wù)?重寫(Overriding) ?。?)父類與子類之間的多態(tài)性,對(duì)父類的函數(shù)進(jìn)行重新定義。如果在子類中定義某方法與其父類有相同的名稱和參數(shù),我們說該方法被重寫 (Overriding)。在Java中,子類可繼承父類中的方法,而不需要重新編寫相同的方法。但有時(shí)子類并不想原封不動(dòng)地繼承父類的方法,而是想作一定的修改,這就需要采用方法的重寫。方法重寫又稱方法覆蓋。 (2)若子類中的方法與父類中的某一方法具有相同的方法名、返回類型和參數(shù)表,則新方法將覆蓋原有的方法。如需父類中原有的方法,可使用super關(guān)鍵字,該關(guān)鍵字引用了當(dāng)前類的父類。 ?。?)子類函數(shù)的訪問修飾權(quán)限不能少于父類的; 下面是重寫的例子: 概念:即調(diào)用對(duì)象方法的機(jī)制。 動(dòng)態(tài)綁定的內(nèi)幕: 1、編譯器檢查對(duì)象聲明的類型和方法名,從而獲取所有候選方法。試著把上例Base類的test注釋掉,這時(shí)再編譯就無法通過。 2、重載決策:編譯器檢查方法調(diào)用的參數(shù)類型,從上述候選方法選出唯一的那一個(gè)(其間會(huì)有隱含類型轉(zhuǎn)化)。如果編譯器找到多于一個(gè)或者沒找到,此時(shí)編譯器就會(huì)報(bào)錯(cuò)。試著把上例Base類的test(byte b)注釋掉,這時(shí)運(yùn)行結(jié)果是1 1。 3、若方法類型為priavte static final ,java采用靜態(tài)編譯,編譯器會(huì)準(zhǔn)確知道該調(diào)用哪個(gè)方法。 4、當(dāng)程序運(yùn)行并且使用動(dòng)態(tài)綁定來調(diào)用一個(gè)方法時(shí),那么虛擬機(jī)必須調(diào)用對(duì)象的實(shí)際類型相匹配的方法版本。在例子中,b所指向的實(shí)際類型是TestOverriding,所以b.test(0)調(diào)用子類的test。但是,子類并沒有重寫test(byte b),所以b.test((byte)0)調(diào)用的是父類的test(byte b)。如果把父類的(byte b)注釋掉,則通過第二步隱含類型轉(zhuǎn)化為int,最終調(diào)用的是子類的test(int i)。 學(xué)習(xí)總結(jié):多態(tài)性是面向?qū)ο缶幊痰囊环N特性,和方法無關(guān),簡(jiǎn)單說,就是同樣的一個(gè)方法能夠根據(jù)輸入數(shù)據(jù)的不同,做出不同的處理,即方法的重載——有不同的參數(shù)列表(靜態(tài)多態(tài)性)而當(dāng)子類繼承自父類的相同方法,輸入數(shù)據(jù)一樣,但要做出有別于父類的響應(yīng)時(shí),你就要覆蓋父類方法,即在子類中重寫該方法——相同參數(shù),不同實(shí)現(xiàn)(動(dòng)態(tài)多態(tài)性) OOP三大特性:繼承,多態(tài),封裝。 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) } } 這時(shí)的輸出結(jié)果是1 0,這是運(yùn)行時(shí)動(dòng)態(tài)綁定的結(jié)果。 |
|