类的主动引用(一定会发生类的初始化)
- 当虚拟机启动,先初始化main方法所在的类
- new一个类的对象
- 调用类的静态成员(除了final常量)和静态方法
- 使用Java.lang.reflect包下的方法对类进行反射调用
- 当初始化一个类,如果父类没有初始化,则会先初始化其父类
类的被动引用(不会发生类的初始化)
- 当访问一个静态域时只有真正生命这个域的类才会被初始化。如:通过子类引用父类的静态变量,不会导致子类的初始化
- 通过数组定义类引用,不会触发此类的初始化
- 引用常量不会触发此类的初始化(常量在链接阶段就已经存到调用类的常量池了)
public class Test05 {
static{
System.out.println("main方法的静态代码块");
}
public static void main(String[] args) throws ClassNotFoundException {
//1.new对象,主动引用
// Father father = new Father();//只会加载父类
// Son son = new Son();//会加载父类和子类
//2.反射也会产生主动引用
// Class c1 = Class.forName("com.kuang.reflect.Father");//同上
//不会发生初始化,通过子类引用父类的静态变量,不会初始化子类
// System.out.println(Son.F);
//调用常量是不会引起父类和子类的初始化
// System.out.println(Son.s);
//通过数组定义类引用,不会触发此类的初始化
// Son[] array = new Son[5];
}
}
class Father{
static int F = 10;
static{
System.out.println("父类的静态代码块");
}
}
class Son extends Father{
static int S = 20;
static final int s = 30;
static{
System.out.println("子类的静态代码块");
}
}