关于构造器调用顺序
http://zhidao.baidu.com/link?url=yaeRyr0If99iZIq7vSKwYJLqEbXQaekYzMSytH39CY8k6B0KNNbpUwwLrydPptG6PnrjYMcgtrijMuds0eviXq
如題,看一下下面的程序,謝謝啦package net.chapter1; class AA{void draw(){System.out.println("AA.draw()");}AA(){System.out.println("AA() before draw()");draw();System.out.println("AA() after draw()");} } public class GouZaoDraw extends AA{private int i=1;GouZaoDraw(int i){this.i=i;System.out.println("GouZaoDraw :"+this.i);}void draw(){System.out.println("GouZaoDraw: "+i);}public static void main(String[] args){new GouZaoDraw(5);} }/* 輸出結果為:AA() before draw() GouZaoDraw: 0 AA() after draw() GouZaoDraw :5我好奇的是AA的構造函數中調用的 draw()為什么是被覆蓋后的draw?按從基類到導出類的順序,draw不是應該還沒被覆蓋的嗎? 哪位達人幫忙解答一下?謝謝先! */ 1.所有的屬性取決于編譯時類型; 2.所有的靜態方法取決于編譯時類型; 3.所有的普通方法取決于運行時類型。 解釋:你的draw方法沒用用static修飾,屬于普通方法,那么就取決于運行時類型。而你main函數中運行時的類型為GouZaoDraw,所以AA的構造函數中調用的draw()就是被覆蓋后GouZaoDraw中的draw()。 new 一個對象的 執行過程是 1.父類的靜態成員變量初始化(按變量聲明順序) 2.父類的靜態代碼塊執行(按代碼塊聲明順序) 3.子類的靜態成員變量初始化(按變量聲明順序) 4.子類的靜態代碼塊執行(按代碼塊聲明順序) 5.父類的實例變量初始化(按變量聲明順序) 6.父類的構造器 7.子類的實例變量初始化(按變量聲明順序) 8.子類的構造器總結
- 上一篇: Restlet入门示例
- 下一篇: 面向消息的中间件 (Message-Or