① 為什麼子類重寫父類的方法的訪問修飾符,不能低於父類的方法訪問許可權
重寫也叫覆寫,修飾符、返回類型、參數就是要和父類一摸一樣才叫覆寫,意思是說各個地方都需要完美的蓋住,在面向介面編程中,重寫是子類有自己的邏輯要實現,同時又不破壞已寫好程序邏輯的好方法
======================================================
舉個例子,在父類中是public的方法,如果子類中將其降低訪問許可權為private,那麼子類中重寫以後的方法對於外部對象就不可訪問了,這個就破壞了繼承的含義
② 重載 和 重寫 的區別
重載: Java的方法重載,就是在類中可以創建多個方法,它們具有相同的名字,但具有不同的參數和不同的定義。調用方法時通過傳遞給它們的不同參數個數和參數類型來決定具體使用哪個方法, 這就是多態性。
重寫:父類與子類之間的多態性,對父類的函數進行重新定義。如果在子類中定義某方法與其父類有相同的名稱和參數,我們說該方法被重寫 (Overriding)。在Java中,子類可繼承父類中的方法,而不需要重新編寫相同的方法。但有時子類並不想原封不動地繼承父類的方法,而是想作一定的修改,這就需要採用方法的重寫。方法重寫又稱方法覆蓋。
簡單說,就是同樣的一個方法能夠根據輸入數據的不同,做出不同的處理,即方法的 重載——有不同的參數列表(靜態多態性)
而當子類繼承自父類的相同方法,輸入數據一樣,但要做出有別於父類的響應時,你就要覆蓋父類方法,即在子類中重寫該方法——相同參數,不同實現(動態多態性)
重寫方法的規則:
1、參數列表必須完全與被重寫的方法相同,否則不能稱其為重寫而是重載。
2、返回的類型必須一直與被重寫的方法的返回類型相同,否則不能稱其為重寫而是重載。
3、訪問修飾符的限制一定要大於被重寫方法的訪問修飾符(public>protected>default>private)
4、重寫方法一定不能拋出新的檢查異常或者比被重寫方法申明更加寬泛的檢查型異常。例如:
父類的一個方法申明了一個檢查異常IOException,在重寫這個方法是就不能拋出Exception,只能拋出IOException的子類異常,可以拋出非檢查異常。
而重載的規則:
1、必須具有不同的參數列表;
2、可以有不責罵的返回類型,只要參數列表不同就可以了;
3、可以有不同的訪問修飾符;
4、可以拋出不同的異常;
重寫與重載的區別在於:
重寫多態性起作用,對調用被重載過的方法可以大大減少代碼的輸入量,同一個方法名只要往裡面傳遞不同的參數就可以擁有不同的功能或返回值。
用好重寫和重載可以設計一個結構清晰而簡潔的類,可以說重寫和重載在編寫代碼過程中的作用非同一般.
③ 重寫和重載的區別是什麼
1、概念不同
重寫:重寫也就是我們通常所說的覆蓋,重寫是指在派生類當中,重新對基類中的虛函數度重新實現。
重載:重載指的是不用的函數使用相同的函數名字,可是,函數的參數、個數或者是類型都不同。
2、規則不同
重載:
重載可以有不同的訪問修飾符。
重載能夠拋出不同的異常。
重載一定要有不同的參數列表。
重寫:
重寫訪問修飾符的限制一定要大於被重寫方法的訪問修飾符。
重寫的參數列表一定要完全和被重寫的方法相同,專否則的話不能稱其為重寫而是重載。
重寫返回的類型一定要一直和被重寫的方法的返回類型相同,否則不能稱其為重寫而是重載。
重寫方法一定不可以拋出新的檢查異常或者是比被重寫方法申明更加寬泛的檢查型異常。
3、類的屬關系不同
重寫:重寫是垂直關系,是子類和父類之間的關系。
重載:重載是水平關系,是同一個類中方法之間的關系。
④ 重寫和重載的區別
重寫和重載的區別
一、規則不同
1、重載規則:
①必須具有不同的參數列表。
②可以有不同的訪問修飾符。
③可以拋出不同的異常。
2、重寫規則:
①參數列表必須完全與被重寫的方法相同。
②返回的類型必須一直與被重寫的方法的返回類型相同。
③訪問修飾符的限制一定要大於被重寫方法的訪問修飾符。
④一定不能拋出新的檢查異常或者比道被重寫方法申明更加寬泛的檢查型異常。
二、類的關系不同
重寫是子類和父類之間的關系,是垂直關系。
重載是同一個類中方法之間的關系,是水平關系。
函數重載的應用
(1)類的構造函數,通常就是函數重載的典型應用。因為一個類通常是可以有很多種構造方式的。
如QT裡面的QString類的構造函數,提供了9種不同的構造函數,這9種構造函數的函數名完全相同,但是它們的參數類型或參數個數卻不完全相同,因此是合法的。
(2)類的成員函數,如賦值函數等。
如VTK的vtkImageData類的兩個成員函數就是重載的。
⑤ 請簡述重載和重寫的區別
重載(overload),方法名稱必須相同,參數必須不同。
重寫(overload),方法名稱必須相同,參數也要相同。
⑥ 不同的休止符各有什麼作用
休止符用以記錄不同長短音的進行的符號叫做音符。 用以記錄不同長短的音的間斷的符號,
每個較大的音值和它最近的較小的音值的比例是2與1之比。例如:全音符等於兩個二分音符;全休止符等於兩個二分休止符等。
休止符是作曲家用來表現作品主題的重要技術手段之一。
⑦ 重載和重寫的區別是什麼
重載和重寫的區別是:
一、定義上的區別:
1、重載是指不同的函數使用相同的函數名,但是函數的參數個數或類型不同。調用的時候根據函數的參數來區別不同的函數。
2、覆蓋(復也叫重寫)是指在派生類中重新對基類中的虛函數(注意是虛函數)重新實現。即函數名和參數都一樣,只是函數的實現體不一樣。
二、規則上的不同:
1、重載制的規則:
①必須具有不同的參數列表。
②可以有不同的訪問修飾符。
③可以拋出不同的異常。
2、重寫方法的規則:
①參數列表必須完全與被重寫的方法相知同,否則不能稱其為重寫而是重載。
②返回的類型必須一直與被重寫的方法的返回類型相同,否則不能稱其為重寫而是重載。
③訪問修飾符的限制一定要大於被重寫方法的訪問修飾符。
④重寫方法一定不能拋出新的檢查異常或者比道被重寫方法申明更加寬泛的檢查型異常,可以拋出運行時異常
三、類的關繫上的區別:
重寫是子類和父類之間的關系,是垂直關系;重載是同一個類中方法之間的關系,是水平關系
⑧ 重載和重寫有什麼區別
重載和重寫的區別有以下幾點:
一、定義上的區別:
1、重載是指不同的函數使用相同的函數名,但是函數的參數個數或類型不同。調用的時候根據函數的參數來區別不同的函數。
2、覆蓋(也叫重寫)是指在派生類中重新對基類中的虛函數(注意是虛函數)重新實現。即函數名和參數都一樣,只是函數的實現體不一樣。
二、規則上的不同:
1、重載的規則:
①必須具有不同的參數列表。
②可以有不同的訪問修飾符。
③可以拋出不同的異常。
2、重寫方法的規則:
①參數列表必須完全與被重寫的方法相同,否則不能稱其為重寫而是重載。
②返回的類型必須一直與被重寫的方法的返回類型相同,否則不能稱其為重寫而是重載。
③訪問修飾符的限制一定要大於被重寫方法的訪問修飾符。
④重寫方法一定不能拋出新的檢查異常或者比被重寫方法申明更加寬泛的檢查型異常。
三、類的關繫上的區別:
重寫是子類和父類之間的關系,是垂直關系;重載是同一個類中方法之間的關系,是水平關系。
⑨ 方法重載和重寫的區別
Overload是重載的意思,表示在同一個類中,允許存在一個以上的同名函數,只要他們的參數個數或者參數類型不同即可,Override是覆蓋的意思,也就是重寫,它與返回值類型無關,只看參數列表,兩者不同主要體現在:目的不同、范圍不同、參數不同、多態性不同、返回類型不同。
1、目的不同
overload用於增加程序的可讀性(做法不同,但是做的同一事情)。 override用於提供其超級類已經提供的方法的特定實現。
2、范圍不同
overload 在相同的類范圍內內執行。 override發生在兩類具有繼承(繼承)的關系。
3、參數不同
overload參數必須不同。 override參數必須相同。
4、多態性不同
overload 靜態多態,調用的函數在編譯時被選中。 override 是運行時多態性的。
5、返回類型不同
overload中可以相同或不同。但你必須改變參數。 override必須是相同的或協變的。
⑩ Java中的重載與重寫有什麼區別(請舉兩個簡單的例子)
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、可以拋出不同的異常;
重寫與重載的區別在於:
重寫多態性起作用,對調用被重載過的方法可以大大減少代碼的輸入量,同一個方法名只要往裡面傳遞不同的參數就可以擁有不同的功能或返回值。
用好重寫和重載可以設計一個結構清晰而簡潔的類,可以說重寫和重載在編寫代碼過程中的作用非同一般.