构造器的最前面其实是隐含了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
    }
} 
总结:
静态代码块、普通代码块和构造器的优先级:
- 静态代码块(静态属性的初始化)
 - 普通代码块(普通属性的初始化)
 - 构造器(构造器的初始化)
 










