文章詳情頁
java - 請問下,這里為何會引發空指針異常?
瀏覽:69日期:2024-01-25 16:13:38
問題描述
有人跟我講,將name進行靜態賦值即可,但實例變量不也是屬于成員變量嗎,也是在整個類實例化的時候產生的啊,跟靜態賦值有何區別嗎?
問題解答
回答1:父類的構造方法先于子類構造方法執行,Base()->test()-->name.length()相當于null.length()。將name寫成靜態的話,當然可以了,因為靜態成員的初始化先于實例成員的初始化。
順序大概是這樣的:
父類static{...}
父類靜態成員
父類構造方法
子類static{...}
子類靜態成員
子類構造方法
回答2:首先拋出一個概念,對象的初始化流程:靜態變量 > 靜態初始化塊 > 實例變量 > 構造器而存在父子類關系的對象,又存在一個嵌套的初始化流程父類初始化流程 > 子類初始化流程
所以在你實例化的過程中,調用父類構造器并調用test()方法時,子類的name還沒有賦值,仍然是null,自然就會報空指針。
回答3:你把name放在父類Base中定義就不會報錯。 因為你實例化Sub時,會調用默認的構造函數,默認的構造函數會調用父類的構造函數,在父類的構造函數中,你使用了test()方法,而你在子類中重寫了該方法,子類的test方法內使用了name,但是這時候name還沒有完成初始化。所以會報NullPointerException。
標簽:
java
相關文章:
排行榜
