jvm 加载类均是采用延时加载的方式 LazyLoading。当不使用一个类的时候肯定是不会去加载的。
在 jvm 规范中,规定了必须加载类的 5 中情形,这里给出,可以结合自己的开发和学习情况很容易想到。无须背过!
- new getstatic putstatic invokestatic 指令,访问 final 除外,因为 final 在编译为 class 文件时就确定好了
- java.lang.reflect 对类反射调用时
- 初始化子类是,父类必定被先加载
- 虚拟机启动时,需要执行的主类需要加载
- 动态语言支持 java.lang.invoke.MethodHandle 解析的结果为 REF_getstatic、REF_putstatic、REF_invokestatic 的方法句柄时,该类被初始化。
- 特别注意: 1:如果一个类被加载了。一定要经历三个阶段,就是类加载子系统的三个阶段:Loading->Linking-> initializing,
- 特别注意 2:在 initializing 时会执行 static 代码块。
利用第二点可以确认此类是否被加载。
package com.yuhl.c2020;
/**
* @author yuhl
* @Date 2020/12/23 21:31
* @Classname lazyLoading
* @Description 懒加载,在需要的时候再加载。
*/
public class lazyLoading {
public static void main(String[] args) throws Exception {
//P p; //单独执行词句:类P不加载
// X x = new X();//单独执行词句:类P加载,因为子类加载前,一定先加载父类
//System.out.println(P.i); //单独执行这句是不会加载的哦。仅有5中情况下会加载哦!
System.out.println(P.j);//单独执行词句:类P加载,特别注意,static的时候需要先加载此类
}
public static class P {
final static int i = 8;
static int j = 9;
static {
System.out.println("P");
}
}
public static class X extends P {
static {
System.out.println("X");
}
}
}
- 明白类的加载不是一股脑的前部加载进内存的
- 按需加载
自律的艰辛总甜过懊悔的苦果!
专注于 java 后端技术及解决方案,善于总结,分享!
自律的艰辛总甜过懊悔的苦果!
专注于 java 后端技术及解决方案,善于总结,分享!
自律的艰辛总甜过懊悔的苦果!
专注于 java 后端技术及解决方案,善于总结,分享!