在網上看到一個很有意思的題目,題目如下
class SingleTon { private static SingleTon singleTon = new SingleTon(); public static int count1; public static int count2 = 1; private SingleTon() { count1++; count2++; } public static SingleTon getInstance() { return singleTon; } } public class Test { public static void main(String[] args) { SingleTon singleTon = SingleTon.getInstance(); System.out.println("count1=" + singleTon.count1); System.out.println("count2=" + singleTon.count2); } }
最開始的時候以為非常簡單就是 count1=1 和 count2=2,但是實際在eclipse里面運行一下才發現答案是錯的
這是就涉及到實例的初始化流程
1.類被加載的時候,普通方法加載到方法區,靜態方法和靜態字段加載到方法區中的靜態區
2.首先靜態字段會進行默認初始化。即 singTon=null count1=0 count2=0
3.然后靜態字段會進行顯示初始化。問題就出現這里(這里就是影響結果的地方)
4.首先 singTon 進行顯示初始化 它會創建 實例,調用構造函數,執行完成以后 此時 count1=1 count2=1
5.然后才是靜態變量 count1和count2進行顯示初始化,因為count1沒有顯示初始化值,所以結果就是 count1=1 但是 count2變量進行完顯示初始化后值就為 1了 (在此過程之前靜態變量count1和count2還沒有進行顯示初始化的)
6.然后執行靜態代碼塊中的內容,此處沒有靜態代碼塊。
所以,綜上 結果是 singTon.count1=1 singTon.count2=1
如果是以下這種情況
class SingleTon { public static int count1; public static int count2 = 1; private static SingleTon singleTon = new SingleTon(); private SingleTon() { count1++; count2++; } public static SingleTon getInstance() { return singleTon; } } public class Demo { public static void main(String[] args) { SingleTon singleTon = SingleTon.getInstance(); System.out.println("count1=" + singleTon.count1); System.out.println("count2=" + singleTon.count2); } }
執行的結果就是 count1=1 count2=2
因為這種情況下, 靜態變量 count2比 singTon 先完成顯示初始化,結果就是我們預料到的
查看詳細解釋 請參考 http://www.cnblogs.com/javaee6/p/3714716.html?utm_source=tuicool&utm_medium=referral