答えは:必ずしも
- 次のコードを実行します。
package com.java.oop;
import java.util.Date;
//-XX:+TraceClassLoading
class ClassDD{
public static final int count=100;
public static final String LOCK="LOCK";
public static final Date date=new Date();
static {
System.out.println("static{}");
}
}
public class TestClassObject09 {
public static void main(String[] args) {
System.out.println(ClassDD.count);
//System.out.println(ClassDD.LOCK);
//System.out.println(ClassDD.date);
}
}
動作結果:
...
...
[Loaded com.java.oop.TestClassObject09 from file:/D:/WORKSPACE/JAVASE-V1.01/bin/]
[Loaded sun.launcher.LauncherHelper$FXHelper from C:\Program Files\Java\jre1.8.0_201\lib\rt.jar]
100
[Loaded java.lang.Shutdown from C:\Program Files\Java\jre1.8.0_201\lib\rt.jar]
[Loaded java.lang.Shutdown$Lock from C:\Program Files\Java\jre1.8.0_201\lib\rt.jar]
分析:実行結果から、ClassDDがロードされていないことがわかります。これは、クラスの静的な最終変更が基本データタイプである場合、初期化はコンパイルフェーズで実行されるためです。
- 次のコードを実行します。
package com.java.oop;
import java.util.Date;
//-XX:+TraceClassLoading
class ClassDD{
public static final int count=100;
public static final String LOCK="LOCK";
public static final Date date=new Date();
static {
System.out.println("static{}");
}
}
public class TestClassObject09 {
public static void main(String[] args) {
//System.out.println(ClassDD.count);
System.out.println(ClassDD.LOCK);
//System.out.println(ClassDD.date);
}
}
運用結果
...
...
[Loaded com.java.oop.TestClassObject09 from file:/D:/WORKSPACE/JAVASE-V1.01/bin/]
[Loaded sun.launcher.LauncherHelper$FXHelper from C:\Program Files\Java\jre1.8.0_201\lib\rt.jar]
LOCK
[Loaded java.lang.Shutdown from C:\Program Files\Java\jre1.8.0_201\lib\rt.jar]
[Loaded java.lang.Shutdown$Lock from C:\Program Files\Java\jre1.8.0_201\lib\rt.jar]
分析:実行結果から、ClassDDがロードされていないことがわかります。これは、クラスの静的な最終変更が文字列タイプの場合、初期化はコンパイルフェーズで実行されるためです。
- 次のコードを実行します。
package com.java.oop;
import java.util.Date;
//-XX:+TraceClassLoading
class ClassDD{
public static final int count=100;
public static final String LOCK="LOCK";
public static final Date date=new Date();
static {
System.out.println("static{}");
}
}
public class TestClassObject09 {
public static void main(String[] args) {
//System.out.println(ClassDD.count);
//System.out.println(ClassDD.LOCK);
System.out.println(ClassDD.date);
}
}
動作結果:
...
...
[Loaded com.java.oop.TestClassObject09 from file:/D:/WORKSPACE/JAVASE-V1.01/bin/]
[Loaded sun.launcher.LauncherHelper$FXHelper from C:\Program Files\Java\jre1.8.0_201\lib\rt.jar]
[Loaded com.java.oop.ClassDD from file:/D:/WORKSPACE/JAVASE-V1.01/bin/]
static{}
...
...
Fri Nov 08 21:54:30 CST 2019
分析:上記の実行結果から、ClassDDクラスがロードされていることがわかります。
概要:クラスの静的finalメンバーにアクセスすると、JVMはコンパイルフェーズ中にクラスのコンパイル最適化を実行します。クラスに静的finalによって変更された基本データタイプと文字列タイプがある場合、初期化はコンパイルフェーズ中に実行されます。