下面小編就為大家帶來一篇Java非靜態成員變數之死迴圈(詳解)。小編覺得蠻不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
1.非靜態成員變數
#當成員變數為非靜態成員變數且對目前類進行實例化時,將會產生死迴圈
範例:
public class ConstructorCls { private ConstructorCls obj=new ConstructorCls(); }
##
public class TestC { public static void main(String[] args) { ConstructorCls c =new ConstructorCls(); } }
結果:
Exception in thread "main" java.lang.StackOverflowError at com.ConstructorCls.<init>(ConstructorCls.java:7) at com.ConstructorCls.<init>(ConstructorCls.java:7) at com.ConstructorCls.<init>(ConstructorCls.java:7)
#分析:當new ConstrutorCls() 會對ConstrutorCls進行實例化,後然對這個類別的成員obj進行初始化,obj又是對自已所在類別進行實列化,這一樣一直下去,直到StackOverflowError
2.靜態成員變數
靜態成員變數是屬於類別的,不會出現死迴圈例如:
public class ConstructorCls { private static ConstructorCls obj=new ConstructorCls(); }
public class TestC { public static void main(String[] args) { ConstructorCls c =new ConstructorCls(); } }
分析:當new ConstructorCls()時,先將ConstructorCls加截到JVM中,在載入時對該類別的靜態成員進行初始化(僅載入時初始化一次),初始化obj物件,new 一個ConstructorCls, 這裡的一個關鍵點是這個靜態成員是屬於類別的,並不屬於某一個實例物件,所以不會產生死迴圈。
以上是Java中非靜態成員變數之死迴圈的詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!