测试代码:
package test; public class Father { static{ System.out.println("父类静态代码块"); } { System.out.println("父类构造代码块"); } public Father(){ System.out.println("父类构造函数"); } public void is(){ System.out.println("父类函数"); { System.out.println("父类局部代码块"); } } public static void main(String[] args) { System.out.println("这是main函数"); Father son = new Son(); son.is(); } } class Son extends Father{ static{ System.out.println("子类静态代码块"); } { System.out.println("子类构造代码块"); } public Son(){ System.out.println("子类构造函数"); } public void is(){ System.out.println("子类函数"); { System.out.println("子类局部代码块"); } } }
执行顺序:
1 Run as java application , 选择父类, 执行顺序:
2 Run as application , 选择子类, 执行顺序:
3 当子类函数和函数的局部代码块上下顺序调换时,执行结果:
4 修改代码,置main函数于子类中,再次测试:
综上,总结如下:
1 同一个class中,构造代码块优先于主函数执行。
2 父类和子类存在时,JVM优先初始化父类,优先执行父类的静态代码块。
3 当选择执行父类时, 尽管在同一个Java文件中,父类的main函数优先于子类的静态构造代码块执行,说明类的初始化实例化和静态代码块的加载是有条件有顺序的,参考:
https://blog.csdn.net/justloveyou_/article/details/72466416 , https://www.cnblogs.com/jpfss/p/9789953.html
4 局部代码块与函数方法,按照由上往下的执行顺序执行
5 执行顺序:
总的来说:父类静态代码块>main函数(处于父类)>子类静态代码块>main函数(处于子类)>父类构造代码块>父类构造函数>子类构造代码块>子类构造函数>子类局部代码块
一般来说: 静态代码块>main函数>构造代码块>构造函数>局部代码块