1. 子類的構造函數假設要引用super的話,必須把super放在函數的首位.
classBase {
Base() {
System.out.println("Base");
}
}
publicclassChecketextendsBase
{
Checket() {
super();//調用父類的構造方法。一定要放在方法的首個語句
System.out.println("Checket");
}
publicstaticvoidmain(String
argv[]) {
Checket c = newChecket();
}
}
假設想用super繼承父類構造的方法,可是沒有放在第一行的話。那麼在super之前的語句。肯定是為了滿足自己想要完畢某些行為的語句,可是又用了super繼承父類的構造方法。那麼曾經所做的改動就都回到曾經了。就是說又成了父類的構造方法了。
2. 在Java中。有時還會遇到子類中的成員變量或方法與超類(有時也稱父類)中的成員變量或方法同名。
由于子類中的成員變量或方法名優先級高,是以子類中的同名成員變量或方法就隐藏了超類的成員變量或方法,可是我們假設想要使用超類中的這個成員變量或方法。就須要用到super.
classCountry {
Stringname;
voidvalue() {
name="China";
}
}
classCityextendsCountry {
Stringname;
voidvalue() {
name="Hefei";
super.value();//不調用此方法時,super.name傳回的是父類的成員變量的值null
System.out.println(name);
System.out.println(super.name);
}
publicstaticvoidmain(String[]
args) {
City c=newCity();
c.value();
}
}
為了在子類中引用父類中的成員變量name和方法value()。在代碼中使用了super、super.name和super.value(),若不調用super.value()時。super.name傳回父類成員變量預設值null,調用此方法時,super.value()方法把成員變量name指派為China,再利用super.name調用父類的成員變量的值。
另外,要注意的是super.name調用的是成員變量的值,
classCountry {
Stringname="xianfan";
String value(String name) {
name ="China";
returnname;
}
}
classCityextendsCountry {
Stringname;
String value(String name) {
name ="Hefei";
super.value("失敗");//不調用此方法時,super.name傳回的是父類的成員變量的值null
System.out.println(name);
System.out.println(super.name);
returnname;
}
publicstaticvoidmain(String[]
args) {
City c=newCity();
c.value("成功");
}
}
結果為:Hefei
xianfan
此時。super.name傳回的值是父類成員變量的值xianfan,而此時的super.value()方法是不起作用的。
3.用super直接傳遞參數:
classPerson {
publicstaticvoidprt(String
s) {
System.out.println(s);
}
Person() {
prt("A Person.");
}
Person(String name) {
prt("A person name is:"+ name);
}
}
publicclassChineseextendsPerson
{
Chinese() {
super();//調用父類構造函數(1)
prt("A chinese.");// (4)
}
Chinese(String name) {
super(name);//調用父類具有同樣形參的構造函數(2)
prt("his name is:"+ name);
}
Chinese(String name,intage) {
this(name);//調用目前具有同樣形參的構造函數(3)
prt("his age is:"+ age);
}
publicstaticvoidmain(String[]
args) {
Chinese cn = newChinese();
cn =newChinese("kevin");
cn =newChinese("kevin",
22);
}
}
結果為:A Person.
A chinese.
A person name is:kevin
his name is:kevin
A person name is:kevin
his name is:kevin
his age is:22
在這段程式中,this和super不再是像曾經那樣用“.”連接配接一個方法或成員。而是直接在其後跟上适當的參數。是以它的意義也就有了變化。super後加參數的是用來調用父類中具有同樣形式的構造函數。如1和2處。
this後加參數則調用的是目前具有同樣參數的構造函數,如3處。
當然,在Chinese的各個重載構造函數中,this和super在一般方法中的各種使用方法也仍可使用,比方4處,你能夠将它替換為“this.prt”(由于它繼承了父類中的那個方法)或者是“super.prt”(由于它是父類中的方法且可被子類訪問),它照樣能夠正确執行。但這樣似乎就有點畫蛇添足的味道了。
4.super和this的異同:
1)super(參數):調用基類中的某一個構造函數(應該為構造函數中的第一條語句)
2)this(參數):調用本類中還有一種形成的構造函數(應該為構造函數中的第一條語句)
3)super: 它引用目前對象的直接父類中的成員(用來訪問直接父類中被隐藏的父類中成員資料或函數,基類與派生類中有同樣成員定義時如:super.變量名 super.成員函資料名(實參)
4)this:它代表目前對象名(在程式中易産生二義性之處,應使用this來指明目前對象;假設函數的形參與類中的成員資料同名,這時需用this來指明成員變量名)
5)調用super()必須寫在子類構造方法的第一行,否則編譯不通過。
每一個子類構造方法的第一條語句,都是隐含地調用super(),假設父類沒有這樣的形式的構造函數。那麼在編譯的時候就會報錯。
6)super()和this()類似,差别是,super()從子類中調用父類的構造方法,this()在同一類内調用其他方法。
7)super()和this()均需放在構造方法内第一行。
8)雖然能夠用this調用一個構造器,但卻不能調用兩個。
9)this和super不能同一時候出如今一個構造函數裡面,由于this必定會調用其他的構造函數。其他的構造函數必定也會有super語句的存在,是以在同一個構造函數裡面有同樣的語句。就失去了語句的意義,編譯器也不會通過。
10)this()和super()都指的是對象,是以,均不能夠在static環境中使用。包含:static變量,static方法,static語句塊。
11)從本質上講,this是一個指向本對象的指針, 然而super是一個Javakeyword。