《Think in JAVA》之每日一读(initianlize)——2013/11/12、13
了解包括繼承在內的初始化全過程,以對所發生的的一切有一個全局的把握,是很有益的。
請看下例:
package initialize;
class Insect {
private int i = 9;
protected int j;
Insect() {
System.out.println("i = " + i + ", j = " + j);
j = 39;
}
private static int x1 = printInit("static Insect.x1 initialized");
static int printInit(String s) {
System.out.println(s);
return 47;
}
}
public class Beetle extends Insect{
private int k = printInit("Beelte.k initialized");
public Beetle(){
System.out.println("k = " + k);
System.out.println("j = " + j);
}
private static int x2 =
printInit("static Beetle.x2 initialized");
public static void main(String[] args) {
System.out.println("Beetle constructor");
//Beetle beetle = new Beetle(); //此處先注釋
}
}
運行結果:
在運行Beetle時,所發生的第一件事就是試圖訪問Beetel.main()方法(程序入口)(一個static方法),
于是加載器就開始啟動并找到Beetel類的編譯代碼(在Beetle.class文件中)。對他進行加載時,發現他有一個基類(這是由“extents”關鍵字得知的),于是繼續進行加載該基類。不管是否你是否打算生成一個該基類的對象,都會發生。從上出代碼Beelte.main()方法中的注釋代碼證明這一點。
如果該基類還有其自身的基類,那么第二個就會被加載,如此類推。接下來,根基類中的static方法初始化(此例中為Insect)即會被執行,然后是下一個導出類,如此類推。
至此,必要的類都加載完畢,對象就可以創建了,我們把上面的Beelte.main()方法中的注釋代碼取消,
運行結果:
首先對象中所有基本類型都會被設為某默認值,對象引用都設為null,然后基類的構造器會被調用。基類的構造器和導出類的構造器一樣,以相同的順序經歷相同的過程?;悩嬙炱魍瓿芍螅瑢嵗兞堪雌浯涡虮怀跏蓟?。
習題:請證明加載類的動作只發生一次。證明該類的第一個實體的創建或static成員的訪問都有可能引起加載。
在Beelte.main()方法中添加一行代碼:
Beetle beetle2 = new Beetle();
輸出結果:
總結
以上是生活随笔為你收集整理的《Think in JAVA》之每日一读(initianlize)——2013/11/12、13的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: JS逆向实战23 某市wss URL加密
- 下一篇: 前端实现电子签名(web、移动端)通用组