A. java 方法的重寫,重載中對於兩個方法修飾符,返回值有什麼要求嗎
java覆蓋,方法的修飾符可以不同,但子類方法的修飾符必須比父類方法的限...
答:子類可以重寫父類的方法,但有幾個需要注意的, 子類重寫修飾不得縮小, 比如父親類中是public 子類重載方法不得變為 private 不得擴大錯誤拋出類型的范圍,比如父類方法中只拋出 NumberF
od方法根本不是重寫的A
的method方法,而是重載。重載要求方法名相同,參數返回值隨便改。
所以,參數不一定改成long,隨便什麼都是重載。也不是必須加@override,寫這個表示eclipse會給你去父類檢查重寫的對不對,不寫就自己檢查唄。
重寫是覆蓋,就是子類的替換了父類的,正常用方法,調的是子類的,所以重寫完還是一個方法
重載是寫多個同名方法,但可以給的參數不同,功能類似,所以正常調哪個方法,要看參數怎麼寫的,跟繼承無關,區別是重載後變成多個方法。
B. java中,重載方法間的修飾符和返回值要一樣嗎
可以不一樣
比如一個public ,一個protected
C. java裡面的重載和重寫,究竟哪個可以改變返回值得類型啊
重載 可以改變返回值類型 參數的個數,類型,都可以,只是函數名相同
重寫,顧名思義,就是對父類的方法進行重新寫過,就是改了作用,名字什麼的都一樣
D. java重載為什麼與返回值無關
因為java里允許調用一個有返回值的方法的時候不必將返回值賦給變數,這樣JVM就不知道你調用的是有返回值的還是沒返回值的。
舉個例子:
classTest{
publicstaticvoidtestMethod(){
}
publicstaticinttestMethod(){
}//姑且假設允許吧
publicstaticvoidmain(String[]args){
inti=testMethod();//這個還說的過去知道是調用哪個
testMethod();//這個就無法判斷調用哪個方法了
}
}
E. JAVA重載方法的返回類型必須一致
返回類型不需要一致
java重載是根據參數的類型和數量來進行判斷的,跟返回值沒有關系
F. java的返回值類型和參數數量不一樣,是重載嗎
這樣不一定是函數重載(overload),也可以是覆蓋(overide)
函數多態性是面向對象編程的核心思想
即允許派生類重新定義基類的虛方法的方法,這就是override。
而重載(overload)是允許同名函數的存在,函數返回值、參數等可以完全不一樣,但要記住,對編譯器來說,它會產生兩個不同名字的函數(自動對名稱進行修飾)
重載函數的入口地址在編譯期間已經是靜態的了
記住,重載只是語言特性,與多態性無關,與面向對象無關
剛打完字就發現已經採納別人了,決定等下報名去打字打字學習班
G. java中重載和重寫的區別是什麼
重載: 發生在同一個類中,方法名必須相同,參數類型不同、個數不同、順序不同,方法返回值和訪問修飾符可以不同,發生在編譯時。
重寫: 發生在父子類中,方法名、參數列表必須相同,返回值范圍小於等於父類,拋出的異常范圍小於等於父類,訪問修飾符范圍大於等於父類;如果父類方法訪問修飾符為 private 則子類就不能重寫該方法。
H. Java中重載可以返回值不同么
方法重載跟返回值類型和修飾符無關 Java的重載 是發生在本類中的,重載的條件是在本類中有多個方法名相同,但參數列表不同(可能是,參數個數不同,參數類型不同),跟返回值無關。 我們可以舉個例子,假如我們在同一個類中,寫了兩個方法名相同並且參數列表也相同,只是返回值不同,public Stringshow(int number)
public int show(int number) 而我們調用這個方法給它賦值的時候java虛擬機並不知道你要賦給的是String型的方法還是int型的方法,所以重載跟返回值無關。
I. Java中重載可以返回值不同么
java中重載就是相同的方法
就是返回類型相同
方法名相同
在參數相同的情況下
參數類型不一樣
在參數不相同的情況下
參數個數不一樣
希望能幫到你
再看看別人怎麼說的。
J. Java重載和重寫
(1)方法重載是讓類以統一的方式處理不同類型數據的一種手段。多個同名函數同時存在,具有不同的參數個數/類型。
重載Overloading是一個類中多態性的一種表現。
(2)java的方法重載,就是在類中可以創建多個方法,它們具有相同的名字,但具有不同的參數和不同的定義。
調用方法時通過傳遞給它們的不同參數個數和參數類型來決定具體使用哪個方法,這就是多態性。
(3)重載的時候,方法名要一樣,但是參數類型和個數不一樣,返回值類型可以相同也可以不相同。無法以返回型別作為重載函數的區分標准。
下面是重載的例子:
packagec04.answer;//這是包名
//這是這個程序的第一種編程方法,在main方法中先創建一個Dog類實例,然後在Dog類的構造方法中利用this關鍵字調用不同的bark方法。
不同的重載方法bark是根據其參數類型的不同而區分的。
//注意:除構造器以外,編譯器禁止在其他任何地方中調用構造器。
packagec04.answer;
publicclassDog{
Dog()
{
this.bark();
}
voidbark()//bark()方法是重載方法
{
System.out.println("nobarking!");
this.bark("female",3.4);
}
voidbark(Stringm,doublel)//注意:重載的方法的返回值都是一樣的,
{
System.out.println("abarkingdog!");
this.bark(5,"China");
}
voidbark(inta,Stringn)//不能以返回值區分重載方法,而只能以「參數類型」和「類名」來區分
{
System.out.println("ahowlingdog");
}
publicstaticvoidmain(String[]args)
{
Dogdog=newDog();
//dog.bark();[Page]
//dog.bark("male","yellow");
//dog.bark(5,"China");
然後我們再來談談重寫(Overriding)
(1)父類與子類之間的多態性,對父類的函數進行重新定義。如果在子類中定義某方法與其父類有相同的名稱和參數,我們說該方法被重寫(Overriding)。在Java中,子類可繼承父類中的方法,而不需要重新編寫相同的方法。
但有時子類並不想原封不動地繼承父類的方法,而是想作一定的修改,這就需要採用方法的重寫。
方法重寫又稱方法覆蓋。
(2)若子類中的方法與父類中的某一方法具有相同的方法名、返回類型和參數表,則新方法將覆蓋原有的方法。
如需父類中原有的方法,可使用super關鍵字,該關鍵字引用了當前類的父類。
(3)子類函數的訪問修飾許可權不能少於父類的;
下面是重寫的例子:
概念:即調用對象方法的機制。
動態綁定的內幕:
1、編譯器檢查對象聲明的類型和方法名,從而獲取所有候選方法。試著把上例Base類的test注釋掉,這時再編譯就無法通過。
2、重載決策:編譯器檢查方法調用的參數類型,從上述候選方法選出唯一的那一個(其間會有隱含類型轉化)。
如果編譯器找到多於一個或者沒找到,此時編譯器就會報錯。試著把上例Base類的test(byteb)注釋掉,這時運行結果是11。
3、若方法類型為priavtestaticfinal,java採用靜態編譯,編譯器會准確知道該調用哪個方法。
4、當程序運行並且使用動態綁定來調用一個方法時,那麼虛擬機必須調用對象的實際類型相匹配的方法版本。
在例子中,雲南java課程http://www.kmbdqn.cn/發現b所指向的實際類型是TestOverriding,所以b.test(0)調用子類的test。
但是,子類並沒有重寫test(byteb),所以b.test((byte)0)調用的是父類的test(byteb)。
如果把父類的(byteb)注釋掉,則通過第二步隱含類型轉化為int,最終調用的是子類的test(inti)。