<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆-55  評論-208  文章-0  trackbacks-0
    昨天在改一處代碼時發現執行的過程和預想的不一樣,仔細探究才發現是構造器執行順序問題.(汗自己一下,基礎不夠扎實)
    特地做了一些嘗試然后把java構造器的執行順序整理出來.
    首先是我測試的代碼:
    public class Son extends Father {
        SonProp r 
    = new SonProp();
        
    public Son() {
            System.out.println(
    "Son is construct");
        }

        
    public static void main(String[] args) {
            
    new Son();
        }

    }

    class Father {
        FatherProp SonProp 
    = new FatherProp();
        
    public Father() {
            System.out.println(
    "Father is construct");
        }

    }

    class SonProp {
        
    public SonProp() {
            System.out.println(
    "SonProp is construct");
        }

    }

    class FatherProp {
        
    public FatherProp() {
            System.out.println(
    "FatherProp is construct");
        }

    }
    執行結果如下:
    FatherProp is construct
    Father is construct
    SonProp is construct
    Son is construct

    由此不難看出java類初始化時構造函數調用順序:
      (1)初始化對象的存儲空間為零或null值;
      (2)按順序分別調用父類成員變量和實例成員變量的初始化表達式;
      (3)調用父類構造函數;(如果實用super()方法指定具體的某個父類構造函數則使用指定的那個父類構造函數)
      (4)按順序分別調用類成員變量和實例成員變量的初始化表達式;
      (5)調用類本身構造函數。

    posted on 2008-05-27 11:43 rocket 閱讀(8198) 評論(6)  編輯  收藏 所屬分類: 經驗積累

    評論:
    # re: 一個以前沒有注意的問題:java構造函數的執行順序 2008-05-27 11:46 | 基金凈值
    我也才知道,謝謝!  回復  更多評論
      
    # re: 一個以前沒有注意的問題:java構造函數的執行順序 2008-05-27 12:30 | 隔葉黃鶯
    借用我在 http://m.tkk7.com/cheneyfree/archive/2008/05/24/202643.html 里寫的回復,再次貼來這里來,與博主共勉

    1. 初始化分為為的初始化和實例的初始化
    2. 每個類在 JVM 中都對應一個 Class 實例
    3. 父類實例是作為子例的部分存在的 (Class 實例之間也存在父子關系)
    4. 初始化實例之前要初始化類

    基于以上幾點就可以理解以下初始化順序
    1. 父類靜態屬性、靜態類 (父類的初始化,對應 JVM 方法 cinit())
    2. 子類的靜態屬性、靜態類 (子類的初始化,對應 JVM 方法 cinit())
    3. 父類的實例構造,實例變量初始化 (實例變量初始實際會放到 JVM 的 init() 中)
    4. 子類的實例構造,實例變量初始化 (也是對應的 init() 方法)

    關于類的 Class 實例,可以回想 Log 的聲明
    Log log = LogFactory.getLog(TestClass.class);
    也就是無論你,new 多少個 TestClass 實例,它們對應著同一個 TestClass 的 Class 實例,也就是為什么很多地方把靜態方法、靜態屬性說成是類的方法、類的屬性,其實質就是在 JVM 中存在同一個 Class 實例的方法、屬性,也就能保持一致性。

    關于父類實例是作為子類的一部分存在,可借鑒 C++ 或是有面向對象特性的 C 函數庫(如 gtk),來理解,父類實例會居于子類實例的首地址,所以對子類轉型成父類實例時,它是安全的,因為首地址一樣的,所以從首地址到 size(父類)就是父類實例地址空間,到size(子類)就是子類實例的地址空間。  回復  更多評論
      
    # re: 一個以前沒有注意的問題:java構造函數的執行順序 2008-05-27 13:02 | rocket
    @隔葉黃鶯

    呵呵,還是我們的黃鶯扎實啊,以前還真沒有仔細研究過jvm。這就去仔細找資料看看。  回復  更多評論
      
    # re: 一個以前沒有注意的問題:java構造函數的執行順序 2008-05-27 17:33 | deathnote
    筆試了幾次,基礎很重要啊,收下了。。。。  回復  更多評論
      
    # re: 一個以前沒有注意的問題:java構造函數的執行順序 2008-05-28 20:49 | Jack.Wang
    LZ 真強大,看來你的 oo 還是不行??!
    最近聽一個牛人(國外留學的 doctor),講中間件的時候講幾次內存模型。真的受益匪淺,改天去你們公司分享一下!  回復  更多評論
      
    # re: 一個以前沒有注意的問題:java構造函數的執行順序 2012-08-08 10:54 | 王鵬飛
    不錯,很有幫助  回復  更多評論
      
    主站蜘蛛池模板: 国产高潮流白浆喷水免费A片 | 拍拍拍无挡视频免费观看1000| 亚洲国产精品成人网址天堂| 国产午夜不卡AV免费| 亚洲精品国产肉丝袜久久| 国产va免费精品观看精品 | 美女在线视频观看影院免费天天看 | 亚洲另类无码专区首页| 亚洲精品无码久久不卡| 久久永久免费人妻精品下载| 亚洲精品无码日韩国产不卡av| 91麻豆精品国产自产在线观看亚洲| 91免费国产精品| 香港经典a毛片免费观看看| 久久亚洲国产欧洲精品一| 妞干网免费观看视频| 成av免费大片黄在线观看| 亚洲一级免费毛片| 久久久亚洲精品蜜桃臀| a毛片基地免费全部视频| 国产高清视频免费在线观看| 伊人久久亚洲综合影院首页| 国产亚洲精品自在久久| 永久黄网站色视频免费观看| 久艹视频在线免费观看| 黄色一级毛片免费| 亚洲国产高清视频在线观看| 91麻豆精品国产自产在线观看亚洲| 蜜桃视频在线观看免费网址入口| 国内精品99亚洲免费高清| 亚洲精品无码高潮喷水A片软| 亚洲va在线va天堂va不卡下载 | 亚洲A丁香五香天堂网| 99久久国产热无码精品免费 | 丁香六月婷婷精品免费观看| 亚洲AV无码久久久久网站蜜桃| 亚洲va无码手机在线电影| 亚洲女人被黑人巨大进入| 国产高清视频在线免费观看| 嫖丰满老熟妇AAAA片免费看| 免费精品久久天干天干|