[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[jfriends-ml 11830] ML 動いてますか?( Re: StaticInitializer の実行タイ ミング)



こんばんは、遠藤です。

ML動いてますか?
昨日、出したメールが届かないようでしたので。

昨日出したメールとその添付ファイルを書きに
つけておきます。

それでは。

Yasuhiro Endoh wrote:
> こんばんは、遠藤です。
> 
> 今日、話題に出た
> staticフィールドの初期化の順序を確認するコードを書きました。
> 
> 添付のファイルには、クラスA、B、Cが定義されています。
> 
> 
>>javac StaticInitTest.java
>>java -verbose StaticInitTest
> 
> 
> とすると、ABCの順、
> 
> 
>>java -verbose StaticInitTest -r
> 
> 
> とすると、CBAの順になります。
> 


-- 
// 遠藤 康裕

public final class StaticInitTest{
    public static void main(String[] args) throws ClassNotFoundException {
        if(args.length > 0 && args[0].equals("-r")) {
            loadCBA();
        } else {
            loadABC();
        }
    }

    public static void loadABC() {
        System.out.println("loadABC");
        System.out.println("A.val=" + A.val);
        System.out.println("B.val=" + B.val);
        System.out.println("C.val=" + C.val);
    }

    public static void loadCBA() throws ClassNotFoundException {
        System.out.println("loadCBA");
        Class.forName("C");
        Class.forName("B");
        Class.forName("A");
    }
}

class A {
    public static int val = 2;
    public static A instance = new A();

    static {
        System.out.println("A's static initializer");
    }

    A() {
        System.out.println("A's constructor");
    }
}

class B {
    public static int val = 3;
    public static B instance = new B();

    static {
        System.out.println("B's static initializer");
    }
    
    B() {
        System.out.println("B's constructor");
    }
}

class C {
    public static int val = 4;
    static {
        System.out.println("C's static initializer");
    }
    public static C instance = new C();

    C() {
        System.out.println("C's constructor");
    }
}