JAVA非靜態成員變量之死循環
阿新 • • 發佈:2017-09-22
又是 sta 所在 rgs style 之死 exce span ring
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非靜態成員變量之死循環