Class.forName("Gum");
这个方法是Class类的一个static方法,Class对象和其他对象一样,我们可以获取并操作它的引用(也就是类加载器的工作)。forName()是取得Class对象的引用的一种方法。它是用一个包含目标类的文本名(注意拼写和大小写)的String作为输入参数,返回的是一个Class对象的引用,上面的代码忽略了返回值。对forName()调用是为了利用它产生的“副作用”:如果类Gum还没有被加载就加载它,在加载的过程中Gum的static子句会被执行。
这个方法是Class类的一个static方法,Class对象和其他对象一样,我们可以获取并操作它的引用(也就是类加载器的工作)。forName()是取得Class对象的引用的一种方法。它是用一个包含目标类的文本名(注意拼写和大小写)的String作为输入参数,返回的是一个Class对象的引用,上面的代码忽略了返回值。对forName()调用是为了利用它产生的“副作用”:如果类Gum还没有被加载就加载它,在加载的过程中Gum的static子句会被执行。
package test;
import java.util.Random;
class Initable{
static final int staticFinal = 47;
static final int staticFinal2 = TestClassInitializeOrder.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("Initializing Initable3");
}
}
public class TestClassInitializeOrder {
public static Random rand = new Random(47);
public static void main(String[] args) throws Exception{
Class initable = Initable.class; //Doesn't trigger initialization
System.out.println("After creating Initable ref");
System.out.println(Initable.staticFinal); //Does trigger initialization
System.out.println(Initable.staticFinal2); //Does trigger initialization
System.out.println(Initable2.staticNonFinal);
Class initable3 = Class.forName("Initable3");
System.out.println("After creating Initable3 ref");
System.out.println(Initable3.staticNonFinal);
}
}
***********************************************************
初始化有效地实现了尽可能的“惰性”。从对initiable引用的创建中可以看到,仅使用.class语法来获得类的引用不会引发初始化。但是为了产生Class引用,Class.forName()立即进行了初始化,就像在对initiable3引用的创建中所看到的。
如果一个static final值是“编译期常量”,就像Initiable.staticFinal那样,那么这个值不需要对Initiable类进行初始化就可以被读取。但是,如果只是将一个域设置为static和final的,还不足以确保这种行为。例如,对Initiable.staticFinal2的访问将进行类的强制初始化,因为它不是一个“编译期常量”。
如果一个static域不是final的,那么对它进行访问时,总是要求在它被读取之前要先进行链接(为这个域分配存储空间)和初始化(初始化该存储空间),就像在对Initiable2.staticNonFinal的访问中所看到的那样。
After creating Initable ref
47
Initializing Initable
258
Initializing Initable2
147
Initializing Initable3
After creating Initable3 ref
74
***********************************************************
After creating Initable3 ref
74
初始化有效地实现了尽可能的“惰性”。从对initiable引用的创建中可以看到,仅使用.class语法来获得类的引用不会引发初始化。但是为了产生Class引用,Class.forName()立即进行了初始化,就像在对initiable3引用的创建中所看到的。
如果一个static final值是“编译期常量”,就像Initiable.staticFinal那样,那么这个值不需要对Initiable类进行初始化就可以被读取。但是,如果只是将一个域设置为static和final的,还不足以确保这种行为。例如,对Initiable.staticFinal2的访问将进行类的强制初始化,因为它不是一个“编译期常量”。
如果一个static域不是final的,那么对它进行访问时,总是要求在它被读取之前要先进行链接(为这个域分配存储空间)和初始化(初始化该存储空间),就像在对Initiable2.staticNonFinal的访问中所看到的那样。