构造器的最前面其实是隐含了super()和调用普通代码块,静态相关的代码块,静态属性初始化,在类加载时,就执行完毕,因此是优先于构造器和普通代码块执行的。
public class Test {
public static void main(String[] args) {
new B2();
}
}
class A1{
static{
System.out.println("A1 的静态代码块被执行。。。");//1
}
{
System.out.println("A1 的普通代码块被执行。。。");//3
}
public A1(){
//因为普通代码块的优先级比构造器高,所以先执行本类的普通代码块,再执行本类的构造器
//本类的普通代码块
System.out.println("A1 的构造器被执行");//4
}
}
class B2 extends A1{
static{
System.out.println("B2类的静态代码块被执行");//2
}
{
System.out.println("B2类的普通代码块被执行");//5
}
public B2(){
System.out.println("B2 的构造器被执行");//6
}
}
总结:
静态代码块、普通代码块和构造器的优先级:
- 静态代码块(静态属性的初始化)
- 普通代码块(普通属性的初始化)
- 构造器(构造器的初始化)