本文目錄一覽:
- 1、JAVA中方法重載和方法重寫的區別和應用?
- 2、java中方法的重載是什麼意思?
- 3、java中重載有什麼用
- 4、java中重載的作用是什麼?
- 5、java中重載和重寫的區別是什麼?
- 6、Java重載和重寫?
JAVA中方法重載和方法重寫的區別和應用?
你好,很高興回答你的問題。
java中方法重載是指在同一個類內,方法名相同,參數列表不同。
而重寫是指子類繼承父類的方法後重新編寫方法內的邏輯。
多態其實就是通過重寫和重載實現的。
各種設計模式也都離不開重新和重載。
如果有幫助到你,請點擊採納。
java中方法的重載是什麼意思?
覆蓋是override方法重寫重載是overload
按照教科書上的定義,重載就是具有相同函數名,返回類型可以不同,參數個數、順序、類型不同的函數。我的理解是重載是發生在兩個或者是更多的函數具有相同的名字的情況下。
重寫就是覆蓋父類的方法,和父類有相同返回類型,參數,甚至是拋出的異常,重寫方法不能為private,運用中最典型的就是對接口方法的覆蓋。方法的重寫Overriding和重載Overloading是Java多態性的不同表現.
重寫Overriding是父類和子類之間多態性的一種表現;如果在子類中定義某方法和其父類有相同的名稱和參數,我們說該方法被重寫(Overriding).子類的對象使用這個方法時,將調用子類中的定義,對他而言,父類中的定義如同被”屏蔽”了.
重載Overloading是個類中多態性的一種表現;如果在一個類中定義了多個同名的方法,他們或有不同的參數個數或有不同的參數類型,則稱為方法的重載(Overloading).重載的方法是能改動返回值的類型.
現實例子:你對比上面看,比如一老爹是木工。兒子繼承老爹也是木工。
老爹有個做柜子的獨特技術(方法),只需要用到工具鎚子和木頭(參數),
兒子根據老爹這個做柜子的技術延伸出很多種技術,他懶得再起名就也對外宣稱叫做柜子獨特技術。
1個繼承自老爹,相同的方法名,相同的工具,但有自己的想法,工序有改動。兒子做木工活用到這個技術方法的話就叫重寫。
另外的自創,但也叫做柜子獨特技術,但用工具不同有:
木頭。(兒子牛,不用鎚子照樣做柜子。。。)
鋸子,木頭。(也是木頭柜子)
鎚子,鐵皮。(鐵皮柜子)
以上3中為重載。
明白?不明白給我發消息。呵呵~
java中重載有什麼用
在Java 中,同一個類中的2個或2個以上的方法可以有同一個名字,只要它們的參數聲明不同即可。在這種情況下,該方法就被稱為重載(overloaded ),這個過程稱為方法重載(method overloading )。方法重載是Java 實現多態性的一種方式。如果你以前從來沒有使用過一種允許方法重載的語言,這個概念最初可能有點奇怪。但是你將看到,方法重載是Java 最激動人心和最有用的特性之一。
當一個重載方法被調用時,Java 用參數的類型和(或)數量來表明實際調用的重載方法的版本。因此,每個重載方法的參數的類型和(或)數量必須是不同的。雖然每個重載方法可以有不同的返回類型,但返回類型並不足以區分所使用的是哪個方法。當Java 調用一個重載方法時,參數與調用參數匹配的方法被執行。
下面是一個說明方法重載的簡單例子:
// Demonstrate method overloading.
class OverloadDemo {
void test() {
System.out.println(“No parameters”);
}
// Overload test for one integer parameter.
void test(int a) {
System.out.println(“a: ” + a);
}
// Overload test for two integer parameters. void test(int a,int b) { System.out.println(“a and b: ” + a + ” ” + b);}
// overload test for a double parameter
double test(double a) {
System.out.println(“double a: ” + a);
return a*a; }}
class Overload {
public static void main(String args[]) {
OverloadDemo ob = new OverloadDemo();
double result;
// call all versions of test()ob.test();ob.test(10);ob.test(10,20);result = ob.test(123.25);System.out.println(“Result of ob.test(123.25): ” + result);
}
}
該程序產生如下輸出:
No parameters
a: 10
a and b: 10 20
double a: 123.25
Result of ob.test(123.25): 15190.5625
從上述程序可見,test()被重載了四次。第一個版本沒有參數,第二個版本有一個整型參數,第三個版本有兩個整型參數,第四個版本有一個double 型參數。由於重載不受方法的返回類型的影響,test()第四個版本也返回了一個和重載沒有因果關係的值。
當一個重載的方法被調用時,Java 在調用方法的參數和方法的自變量之間尋找匹配。但是,這種匹配並不總是精確的。在一些情況下,Java 的自動類型轉換也適用於重載方法的自變量。例如,看下面的程序:
// Automatic type conversions apply to overloading.
class OverloadDemo {
void test() {
System.out.println(“No parameters”);
}
// Overload test for two integer parameters. void test(int a,int b) { System.out.println(“a and b: ” + a + ” ” + b);}
// overload test for a double parameter
void test(double a) {
System.out.println(“Inside test(double) a: ” + a);
}
}
class Overload {
public static void main(String args[]) {
OverloadDemo ob = new OverloadDemo();
int i = 88;
ob.test();ob.test(10,20);
ob.test(i); // this will invoke test(double)
ob.test(123.2); // this will invoke test(double)
}
}
該程序產生如下輸出:
No parameters
a and b: 10 20
Inside test(double) a: 88
Inside test(double) a: 123.2
在本例中,OverloadDemo 的這個版本沒有定義test(int) 。因此當在Overload 內帶整數參數調用test()時,找不到和它匹配的方法。但是,Java 可以自動地將整數轉換為double 型,這種轉換就可以解決這個問題。因此,在test(int) 找不到以後,Java 將i擴大到double 型,然後調用test(double) 。當然,如果定義了test(int) ,當然先調用test(int) 而不會調用test(double) 。只有在找不到精確匹配時,Java 的自動轉換才會起作用。
方法重載支持多態性,因為它是Java 實現「一個接口,多個方法」范型的一種方式。要理解這一點,考慮下面這段話:在不支持方法重載的語言中,每個方法必須有一個惟一的名字。但是,你經常希望實現數據類型不同但本質上相同的方法。可以參考絕對值函數的例子。在不支持重載的語言中,通常會含有這個函數的三個及三個以上的版本,每個版本都有一個差別甚微的名字。例如,在C語言中,函數abs( )返回整數的絕對值,labs( ) 返回long 型整數的絕對值( ),而fabs( )返回浮點值的絕對值。儘管這三個函數的功能實質上是一樣的,但是因為C語言不支持重載,每個函數都要有它自己的名字。這樣就使得概念情況複雜許多。儘管每一個函數潛在的概念是相同的,你仍然不得不記住這三個名字。在Java 中就不會發生這種情況,因為所有的絕對值函數可以使用同一個名字。確實,Java 的標準的類庫包含一個絕對值方法,叫做abs ( )。這個方法被Java 的math 類重載,用於處理數字類型。Java 根據參數類型決定調用的abs()的版本。
重載的價值在於它允許相關的方法可以使用同一個名字來訪問。因此,abs這個名字代表了它執行的通用動作(general action )。為特定環境選擇正確的指定(specific )版本是編譯器要做的事情。作為程序員的你,只需要記住執行的通用操作就行了。通過多態性的應用,幾個名字減少為一個。儘管這個例子相當簡單,但如果你將這個概念擴展一下,你就會理解重載能夠幫助你解決更複雜的問題。
當你重載一個方法時,該方法的每個版本都能夠執行你想要的任何動作。沒有什麼規定要求重載方法之間必須互相關聯。但是,從風格上來說,方法重載還是暗示了一種關係。這就是當你能夠使用同一個名字重載無關的方法時,你不應該這麼做。例如,你可以使用sqr這個名字來創建一種方法,該方法返回一個整數的平方和一個浮點數值的平方根。但是這兩種操作在功能上是不同的。按照這種方式應用方法就違背了它的初衷。在實際的編程中,你應該只重載相互之間關係緊密的操作。
7.1.1 構造函數重載
除了重載正常的方法外,構造函數也能夠重載。實際上,對於大多數你創建的現實的
類,重載構造函數是很常見的,並不是什麼例外。為了理解為什麼會這樣,讓我們回想上一章中舉過的Box類例子。下面是最新版本的Box類的例子:
class Box { double width; double height; double depth;
// This is the constructor for Box.
Box(double w,double h,double d) {width = w; height = h;depth = d;
}
// compute and return volume double volume() { return width * height * depth;}}
在本例中,Box() 構造函數需要三個自變量,這意味着定義的所有Box對象必須給Box() 構造函數傳遞三個參數。例如,下面的語句在當前情況下是無效的:
Box ob = new Box();
因為Box( )要求有三個參數,因此如果不帶參數的調用它則是一個錯誤。這會引起一些重要的問題。如果你只想要一個盒子而不在乎 (或知道)它的原始的尺寸該怎麼辦?或,如果你想用僅僅一個值來初始化一個立方體,而該值可以被用作它的所有的三個尺寸又該怎麼辦?如果Box 類是像現在這樣寫的,與此類似的其他問題你都沒有辦法解決,因為你只能帶三個參數而沒有別的選擇權。
幸好,解決這些問題的方案是相當容易的:重載Box 構造函數,使它能處理剛才描述的情況。下面程序是Box 的一個改進版本,它就是運用對Box構造函數的重載來解決這些問題的:
/* Here,Box defines three constructors to initialize
the dimensions of a box various ways.
*/
class Box {
double width; double height; double depth; // constructor used when all dimensions specified Box(double w,double h,double d) {
width = w;
height = h;
depth = d;
}
// constructor used when no dimensions specified Box() { width = -1; // use -1 to indicate
height = -1; // an uninitialized
depth = -1; // box
}
// constructor used when cube is created Box(double len) { width = height = depth = len;}
// compute and return volume double volume() { return width * height * depth;}}
class OverloadCons {
public static void main(String args[]) { // create boxes using the various constructorsBox mybox1 = new Box(10,20,15);Box mybox2 = new Box();Box mycube = new Box(7);
double vol;
// get volume of first box
vol = mybox1.volume();
System.out.println(“Volume of mybox1 is ” + vol);
// get volume of second box
vol = mybox2.volume();
System.out.println(“Volume of mybox2 is ” + vol);
// get volume of cube
vol = mycube.volume();
System.out.println(“Volume of mycube is ” + vol);
}
}
該程序產生的輸出如下所示:
Volume of mybox1 is 3000.0
Volume of mybox2 is -1.0
Volume of mycube is 343.0
在本例中,當new執行時,根據指定的自變量調用適當的構造函數。
java中重載的作用是什麼?
重載跟重寫
overload和override,是java多態型的兩種不同表現,
重載是靜態多態性,即同名不同參
好比一個人可以用不同種餐具。
重寫就是覆蓋,動態多態性,同名又同參
好比一個人我不用餐具吃飯了一樣我讓人喂!
java中重載和重寫的區別是什麼?
重載: 發生在同一個類中,方法名必須相同,參數類型不同、個數不同、順序不同,方法返回值和訪問修飾符可以不同,發生在編譯時。
重寫: 發生在父子類中,方法名、參數列表必須相同,返回值範圍小於等於父類,拋出的異常範圍小於等於父類,訪問修飾符範圍大於等於父類;如果父類方法訪問修飾符為 private 則子類就不能重寫該方法。
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課程發現b所指向的實際類型是TestOverriding,所以b.test(0)調用子類的test。
但是,子類並沒有重寫test(byteb),所以b.test((byte)0)調用的是父類的test(byteb)。
如果把父類的(byteb)注釋掉,則通過第二步隱含類型轉化為int,最終調用的是子類的test(inti)。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/248116.html