Java类的加载

本文详细介绍了Java类的加载过程,包括加载、验证、准备、解析和初始化五个阶段。同时,讲解了类加载器的类型,如引导类加载器、扩展类加载器和应用程序类加载器,并阐述了双亲委派机制的工作原理和目的,包括防止核心API被篡改和避免类的重复加载。此外,还讨论了如何自定义类加载器以及打破双亲委派机制的方法。
摘要由CSDN通过智能技术生成

Java类的加载

类的加载过程

加载 -> 验证 -> 准备 -> 解析 -> 初始化

  • 加载:根据类的全限定名称找到类的字节码文件,只有类在使用的时候才会加载。
  • 验证:验证字节码文件的正确性。
  • 准备:为静态变量分配内存,赋默认值。
  • 解析:将字符引用转换成直接引用。
  • 初始化:为静态变量赋值,执行静态代码块。

类加载器

  • 引导类加载器:负责加载支撑JVM运行的位于JRE的lib目录下的核心类库,比如 rt.jar、charsets.jar等。
  • 扩展类加载器:负责加载支撑JVM运行的位于JRE的lib目录下的ext扩展目录中的JAR 类包。
  • 应用程序类加载器:负责加载ClassPath路径下的类包,主要是加载自己写的那些类。
  • 自定义加载器:负责加载用户自定义路径下的类包。

双亲委派机制

原理

加载一个类的时候,使用的加载器如果有父加载器,就会交给父加载器来加载,如果没有父加载器,就会尝试加载,如果不能加载就会委派给子加载器进行加载。

源码:

if (parent != null) {
    c = parent.loadClass(name, false);
} else {
    c = findBootstrapClassOrNull(name);
}

原因

沙箱安全机制:自己写的java.lang.String.class类不会被加载,这样便可以防止核心API库被随意篡改。
避免类的重复加载:当父亲已经加载了该类时,就没有必要子ClassLoader再加载一次,保证被加载类的唯一性。

加载过程

先查找类是否已经加载,如果已经加载了,直接返回,如果没有加载,就会去加载类,最终调用的是native方法。

自定义类加载器

自定义类加载器只需要继承java.lang.ClassLoader类,有两个核心方法:

  • loadClass(),默认实现了双亲委派机制,如果需要打破双亲委派机制,则需要重写此方法。
  • findClass(),默认实现的是空方法,自定义类加载器主要是重写此方法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值