静态代码块
随着类的加载而执行,而且只执行一次,执行优先级高于非静态代码块,于类初始化时执行,执行完即销毁,用于初始化类变量,如static修饰的静态变量。
用法如下:
private static Properties props;
static{
props = new Properties();
}
非静态代码块
在静态代码块执行后,在构造函数执行时,在构造函数主体执行之前被执行
用法如下:
{
}
代码块执行顺序
静态代码块>非静态代码块>构造函数
代码块中的继承问题
代码测试如下:
父类:
public class Father {
static {
System.out.println("执行父类的静态代码块");
}
{
System.out.println("执行父类的非静态代码块");
}
public Father(){
System.out.println("执行父类的构造方法");
}
public static void main(String[] args) {
System.out.println("执行父类中的main方法");
new Son();
}
}
子类:
public class Son extends Father{
static {
System.out.println("执行子类的静态代码块");
}
{
System.out.println("执行子类的非静态代码块");
}
public Son(){
System.out.println("执行子类的构造方法");
}
public static void main(String[] args) {
System.out.println("执行子类中的main方法");
new Son();
}
}
执行子类的main方法结果:
执行父类的main方法结果:
- 子类继承父类,执行子类中的main方法,子类继承了父类,会先执行父类静态代码块,再执行子类的静态代码块
- 执行父类的main方法,在main方法中new子类,首先执行父类的静态代码块,然后是执行子类的静态代码块,(按继承关系,父类的静态代码块还会执行)但是由于静态代码块是随类的加载而执行且执行一次,父类的静态代码块只执行了一次,但非静态代码块会随类的加载而执行,每加载一次执行一次