原創作品,可以轉載,但是請標注出處地址http://www.cnblogs.com/V1haoge/p/5454849.html。
this關鍵字:
this代表當前對象,它有以下幾種用途:
1、本類中在非靜態方法中條用非靜態變量和方法,就可以使用【this.變量名】和【this.方法名(參數列表)】的方式調用,實際情況是,this關鍵字通常會被省略。
2、就在上面這種情況下,有一個特殊情況,那就是在方法中定義了一個與類成員變量同名的局部變量,這是在方法內部調用類的成員變量就必須使用this關鍵字來點用。
3、在構造方法中使用:在存在構造方法重構(overlode)的類中,使用【this(參數列表)】的方式調用本類中的其他構造方法,且必須放置於構造方法的第一句。
super關鍵字:
super代表父類對象,它與this不同,用途如下:
1、子類重寫父類方法之后,再次調用父類的該方法,必須使用【super.方法名(參數列表)】調用。
2、子類的構造方法中默認存在父類的無參構造方法,也可以顯式聲明其他的構造方法,聲明必須使用【super(列表參數)】。
3、在構造方法中,super與this關鍵字不能同時出現,且均位於構造方法首行。
類的封裝:
為了保護類內部內容的安全,不被客戶程序任意調用,將這些內容修飾為private,這些內容將只會對本類可見,包括子類在內的任何異類均無訪問權限,為了實現對這些數據的訪問修改,添加了setName(參數列表)和getName()公共方法來被外部類調用。這樣避免了數據的無端訪問,保護了數據的安全,即封裝。
類的繼承:
1、一個類可以繼承另一個類,這樣前者就擁有后者內部的所有內容,但是父類中的被private修飾的內容子類是無法訪問的,這時在子類中使用父類中的內容相當於使用本類中的內容。
2、被final修飾的類無法被繼承。
3、一個類只能繼承一個類,即單繼承,繼承使用extends關鍵字。
4、構造方法不能被繼承
5、父類中的靜態變量在子類中訪問時,可以you父類點用,子類點用,直接使用三種方式,他們的作用一樣。
6、子類的構造方法必須包含父類的構造方法,即在創建子類的對象實例時,會優先調用父類的構造方法來創建父類的實例對象,再調用子類的構造方法創建子類的實例對象。
7、子類匯總的構造方法默認調用父類的無參構造方法(隱式調用),亦可人為顯式指定某個父類構造方法:使用【super(參數列表)】調用
8、類的繼承通常會使用到重寫操作(override),在保證父類某個方法的返回值、名稱、參數列表不變的情況下優化更改方法體,重寫后的方法不能使用比父類中被重寫方法的更嚴格的權限修飾。
9、父類中的某個方法被子類重寫之后,想要調用父類中的原方法,需要借助【super.方法名(參數列表)】調用。
10、在子類創建對象時,會在內存中加載子類字節碼文件,加載時發現其繼承自父類,那么會轉向加載父類的字節碼文件,在父類的字節碼文件加載完成后,再返回來繼續加載子類的字節碼文件,加載完成后才會開始執行創建對象操作,創建子類對象時,調用子類構造方法必然會先調用父類的構造方法創建父類的對象,之后才會創建子類對象。
下面是實驗代碼:自行查看
父類:Test163
1 public class Test163 { 2 3 //聲明父類的成員變量 4 private String name; 5 protected static int age;//此處設置為protected,目的是為了試驗主類靜態變量的調用方式的區別 6 private String sex; 7 8 //聲明父類的成員方法 9 public String getName() { 10 return name; 11 } 12 public void setName(String name) { 13 this.name = name;//此處使用this用於區分類的成員變量與該方法的局部變量 14 } 15 public int getAge() { 16 return age; 17 } 18 public void setAge(int age) { 19 this.age = age; 20 } 21 public String getSex() { 22 return sex; 23 } 24 public void setSex(String sex) { 25 this.sex = sex; 26 } 27 28 //父類的outPut()方法 29 public void outPut(){ 30 System.out.println("我叫"+name+",今年"+age+"了,我是"+sex+"孩!"); 31 } 32 33 //父類的構造方法(無返回值) 34 //無參構造方法 35 public Test163(){ 36 System.out.println("父類無參構造方法"); 37 } 38 //帶參數的構造方法 39 public Test163(int i){ 40 this(); 41 System.out.println("先調用無參構造方法,在執行這句創建父類對象"); 42 } 43 }
下面是子類:Test1631
1 public class Test1631 extends Test163{ 2 3 //子類的自有變量 4 private String tel; 5 6 //子類自有方法 7 public String getTel() { 8 return tel; 9 } 10 public void setTel(String tel) { 11 this.tel = tel; 12 } 13 14 //重寫父類outPut()方法 15 public void outPut(){ 16 System.out.println("我叫"+getName()+",今年"+getAge()+"了,我是"+getSex()+"孩,我的電話是"+getTel()); 17 } 18 19 //子類的構造方法 20 //子類的無參構造方法 21 public Test1631(){ 22 this(2);//此處不會直接調用父類的構造方法
23 System.out.println("先調用本類中的有參數構造方法,在執行此句"); 24 } 25 //子類的有參數構造方法 26 public Test1631(int j){ 27 super(3); 28 System.out.println("會先調用父類的有參數構造方法創建父類對象,之后執行此句"); 29 } 30 //主方法 31 public static void main(String[] args) { 32 33 //這三種調用方式效果一樣 34 System.out.println("這是測試父類的靜態變量的調用方式的區別:無區別,效果一致"); 35 Test163.age=1; 36 Test1631.age=2; 37 age=3; 38 //輸出上邊的結果 39 System.out.println(Test163.age+" "+Test1631.age+" "+age);//此處輸出結果為333 40 System.out.println("****************************"); 41 //在靜態方法中調用非靜態成員需要創建實例對象,由於要使用到父類與子類所有的變量與方法,所以創建子類的實例對象即可。 42 System.out.println("下面測試子類中創建對象實例的過程"); 43 Test1631 test = new Test1631(); 44 System.out.println("****************************"); 45 System.out.println("下面測試隊封裝性父類進行賦值"); 46 test.setName("張三");//賦值 47 test.setAge(20);//賦值 48 test.setSex("男");//賦值 49 test.setTel("12345678910");//賦值 50 test.outPut();//輸出結果為:我叫張三,今年20了,我是男孩,我的電話是12345678910 51 } 52 }
下方為輸出結果:

這是測試父類的靜態變量的調用方式的區別:無區別,效果一致 3 3 3 **************************** 下面測試子類中創建對象實例的過程 父類無參構造方法 先調用無參構造方法,在執行這句創建父類對象 會先調用父類的有參數構造方法創建父類對象,之后執行此句 先調用本類中的有參數構造方法,在執行此句 **************************** 下面測試隊封裝性父類進行賦值 我叫張三,今年20了,我是男孩,我的電話是12345678910