实例解析JAVA中代码的加载顺序
Java中代码的加载顺序所能了解的知识点
类的依赖关系
static代码块的加载时间
继承类中构造器的隐式调用
非static的成员变量初始化时间
main方法和static的加载顺序
测试代码如下:
public class App { private static App d = new App(); private SubClass t = new SubClass(); static{ System.out.println("App static");//6 } public App(){ System.out.println("构建App");//5 } public static void main(String[] args) { System.out.println("App main");//7 } } //父类 class SuperClass{ static{ System.out.println("SuperClass static");//1 } SuperClass(){ System.out.println("构建SuperClass");//3 } } //子类 class SubClass extends SuperClass{ static{ System.out.println("SubClass static");//2 } public SubClass(){ //super() System.out.println("构建SubClass");//4 } }
输出结果
SuperClass static SubClass static 构建SuperClass 构建SubClass 构建App App static App main
分析
因为在App类中,声明了SubClass的变量,所以JVM先加载SubClass类,不然无法编译App。
SubClass是SuperClass的子类,在继承关系的类中,父类先加载进JVM,不然子类无法编译。
在类中static代码会在字节码文件加载进JVM的时候调用一次,且在该类的生命周期中只会调用一次。所以在第一行输出的是SuperClass static,随后SubClass加载进了JVM,输出第二行的SubClass static
声明的static成员变量,其初始化是在static代码块中。非static成员变量,其初始化是在构造器中,且是在构造器的代码前面。
创建静态的成员变量d之前会先创建成员变量t,在SubClass的构造器中会隐式的使用super()调父类的构造器,所以第三行输出构建SuperClass,第四行输出SubClass。
在App的构造器中创建好了成员变量t后,向下执行,输出第五行的构建App
。
随后继续执行App的静态代码块(因为d是static的变量,所以并不是说App的构造器比static先执行),输出第六行的App static
。
最后执行public类的入口方法main,输出第七行的App main
。
希望本篇文章对您有所帮助
相关文章
springboot 2.3之后消失的hibernate-validator解决方法
这篇文章主要介绍了springboot 2.3之后消失的hibernate-validator解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2020-08-08Java Management Extensions管理扩展原理解析
这篇文章主要介绍了Java Management Extensions管理扩展原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下2020-04-04
最新评论