類成員變量的初始化

1-1 類成員變量初始化的分類

類成員變量的初始化可簡單分爲兩類:非靜態成員變量的初始化(如下簡稱「普通初始化」)和靜態成員變量的初始化(「靜態初始化」)。ide

 

1-2 與初始化相關的規律

  1. 構造函數實際上也是靜態方法;
  2. 首次建立類對象、訪問類的靜態成員(變量或方法)會引起類加載; 
  3. 類加載時會觸發靜態初始化;
  4. 普通初始化會在任何非靜態方法(但包括構造函數)被調用前完成;
  5. 靜態初始化會在任何方法被調用前完成;
  6. 總結四、5點有:調用除構造函數外靜態方法只會引起靜態初始化,而不會引起普通初始化。

 

1-3 類成員變量的初始化順序

  1. 變量(不管是靜態成員變量仍是非靜態成員變量)定義的前後順序決定了初始化順序;
  2. 順序優先級:靜態成員變量 = 靜態代碼塊 > 非靜態成員變量 = 非靜態代碼塊 > 構造函數

 

1-4 相關案例

class Cup{
    Cup(int marker){
        System.out.println("Cup("+marker+")");
    }

    void f1(int marker){
        System.out.println("f1("+marker+")");
    }
}

class Cups{
    static Cup cup1 = new Cup(1);
    Cup cup2 = new Cup(2);
    {
        Cup cup3 = new Cup(3);
    }
    static{
        Cup cup4 = new Cup(4);
    }

    Cups(){
        System.out.println("Cups()");
    }

    static void f2(int marker){
        System.out.println("f2("+marker+")");
    }
}

public class ExplicitStatic {
    public static void main(String[] args) {
        System.out.println("Inside main()");
        Cups.f2(5);
//        Cups cups = new Cups();
    }
}

輸出結果爲:函數

Inside main()
Cup(1)
Cup(4)
f2(5)

Process finished with exit code 0

此結果驗證了1-2中的規律6:調用除構造函數外靜態方法只會引起靜態初始化,而不會引起普通初始化。由於類中的普通成員變量cup二、cup3並未被顯示初始化。spa

 

public class ExplicitStatic {
    public static void main(String[] args) {
        System.out.println("Inside main()");
//        Cups.f2(5);
        Cups cups = new Cups();
    }
}

輸出的結果爲:code

Inside main()
Cup(1)
Cup(4)
Cup(2)
Cup(3)
Cups()

Process finished with exit code 0

此結果驗證了1-2中的規律四、5 以及 初始化順序的優先級。對象

相關文章
相關標籤/搜索