初始化有效地实现了尽可能的"惰性"。从对 initable引用的创建中可以看到,
仅使用.class语法来获得对类的引用不会引发初始化。但是,为了产生Class
引用,Class.forName()立即就进行了初始化,就想在对initable3引用的创建
中看到的。
如果一个static final值是"编译期常量",就想Initable.staticFinal那样,
那么这个值不需要对Initable类进行初始化就可以被读取。但是,如果只是一个
域设置为static和final的,还不足以去确保这种行为。
如果一个static域不是final的,那么对它访问时,纵使要求它被读取之前,
要先进行链接(为这个域分配存储空间)和初始化(初始化该存储空间), 就像在对
Initable2.staticNonFinal的范文中看到的那样。
package TypeInfo;
import java.util.Random;
class Initiable{
static final int staticFinal = 47;
static final int staticFinal2 = ClassInitialization.rand.nextInt(1000);
static{
System.out.println("Initializing Initable");
}
}
class Initable2{
static int staticNonFinal = 147;
static{
System.out.println("Initializing Initable2");
}
}
class Initable3{
static int staticNonFinal = 74;
static{
System.out.println("Initalizing Initable2");
}
}
public class ClassInitialization {
public static Random rand = new Random(47);
public static void main(String[] args) {
Class initable = Initiable.class;
System.out.println("After Creating Initable ref");
// Does not trigger initialization
System.out.println(Initiable.staticFinal);
// Does trigger initialization;
System.out.println(Initiable.staticFinal2);
// Does trigger initialization;
System.out.println(Initable2.staticNonFinal);
System.out.println("After creating Initables3 ref");
System.out.println(Initable3.staticNonFinal);
}
}