0

0

Java面试之Java类加载器的分类与职责

幻夢星雲

幻夢星雲

发布时间:2026-01-14 20:23:02

|

835人浏览过

|

来源于php中文网

原创

bootstrap classloader 由 c++ 实现,加载 $java_home/jre/lib 下的核心类(如 java.lang.object),不继承 java.lang.classloader,故 string.class.getclassloader() 返回 null,且无法通过 java 代码直接引用或获取。

java面试之java类加载器的分类与职责

Bootstrap ClassLoader 加载什么、为什么不能被 Java 代码直接引用

Bootstrap ClassLoader 是由 C++ 实现的,负责加载 $JAVA_HOME/jre/lib 下的核心类(如 java.lang.Objectjava.util.ArrayList),它不继承自 java.lang.ClassLoader,因此任何 Java 代码中调用 String.class.getClassLoader() 都会返回 null

常见误区是以为能用 ClassLoader.getSystemClassLoader().getParent().getParent() 拿到它——实际上 .getParent() 链在 Bootstrap 层就断了,再调用会得到 null,不是抛异常。

  • 它不参与双亲委派链的“Java 层调用”,但它是整个委派机制的起点
  • 无法通过 new 或反射创建,JVM 启动时硬编码绑定
  • 如果手动把 rt.jar(或模块化后的 java.base)里的类复制到 classpath,JVM 仍优先走 Bootstrap 加载,不会交由 AppClassLoader 处理

Extension ClassLoader 和 AppClassLoader 的路径与替换风险

ExtClassLoader(现在更常称 PlatformClassLoader,JDK 9+)默认加载 $JAVA_HOME/jre/lib/ext(或 java.ext.dirs 指定路径)下的 JAR;AppClassLoader(即 SystemClassLoader)加载 -classpathCLASSPATH 环境变量指定的路径。

注意 JDK 9 引入模块系统后,ExtClassLoader 已被标记为过时,PlatformClassLoader 负责加载平台模块(如 java.xml),但它的父加载器仍是 null(逻辑上等价于 Bootstrap)。

立即学习Java免费学习笔记(深入)”;

卡拉OK视频制作
卡拉OK视频制作

卡拉OK视频制作,在几分钟内制作出你的卡拉OK视频

下载
  • 不要往 lib/ext 放业务 JAR:它会变成“准系统级”类,可能被所有应用共享,引发版本冲突
  • -Xbootclasspath/a: 追加的路径,会被 Bootstrap 加载器处理,绕过双亲委派检查,极易破坏类型一致性
  • AppClassLoader 的加载路径可在运行时通过 System.getProperty("java.class.path") 查看,但修改该属性不影响已启动的类加载行为

自定义 ClassLoader 必须重写 findClass(),而不是 loadClass()

直接重写 loadClass() 容易破坏双亲委派模型——比如忘了调用 super.loadClass(name),会导致 java.lang.* 类无法加载,JVM 直接崩溃。

正确做法是继承 ClassLoader,只重写 findClass(String name),在里面实现自己的字节码获取逻辑(如从网络、加密文件、数据库读取),然后调用 defineClass() 转成 Class 对象。JVM 会保证先走父加载器,失败后再进 findClass()

public class MyClassLoader extends ClassLoader {
    private final byte[] bytecode;

    public MyClassLoader(byte[] bytecode) {
        this.bytecode = bytecode;
    }

    @Override
    protected Class<?> findClass(String name) throws ClassNotFoundException {
        try {
            return defineClass(name, bytecode, 0, bytecode.length);
        } catch (Throwable t) {
            throw new ClassNotFoundException(name, t);
        }
    }
}
  • 不要在 findClass() 里调用 loadClass(),会引发无限递归
  • defineClass() 会校验字节码格式和签名,若校验失败抛 ClassFormatError,不是 ClassNotFoundException
  • 同一个 ClassLoader 实例多次加载同一类名,会抛 LinkageError: duplicate class definition

类隔离场景下,ClassLoader 的实例边界比 package 更关键

Web 容器(如 Tomcat)或 OSGi 中的模块隔离,本质靠不同 ClassLoader 实例实现。即使两个类全限定名完全一样(如 com.example.Service),只要由不同加载器加载,JVM 就视为完全不同的类型,不能强转、不能共用静态变量、不能作为方法参数互相传递。

典型错误是把某个类的实例缓存到静态字段里,却没意识到该类可能被多个加载器加载——结果 A 模块的 Service 和 B 模块的 Service 在运行期是“同名异类”。

  • 判断类是否相同,得看 class1 == class2,而不是 class1.getName().equals(class2.getName())
  • 跨加载器通信必须通过接口(且接口由父加载器提供),否则编译期通过、运行期 ClassCastException
  • 线程上下文类加载器(Thread.currentThread().getContextClassLoader())常被用来打破双亲委派,但需明确谁设置、何时重置,否则泄漏导致内存问题

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
如何配置Tomcat环境变量
如何配置Tomcat环境变量

配置Tomcat环境变量需要在系统中添加CATALINA_HOME变量,并将Tomcat的安装路径添加到PATH变量中。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

117

2023.10.26

idea如何集成Tomcat
idea如何集成Tomcat

idea集成Tomcat的步骤:1、添加Tomcat服务器配置;2、配置项目部署;3、运行Tomcat服务器;4、访问项目;5、注意事项;6、关闭Tomcat服务器。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

172

2024.02.23

怎么查看Tomcat源代码
怎么查看Tomcat源代码

查看Tomcat源代码的步骤:1、下载Tomcat源代码;2、在IDEA中导入Tomcat源代码;3、查看源代码;4、理解Tomcat的工作原理;5、参与社区和贡献;6、注意事项;7、持续学习和更新;8、使用工具和插件。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

98

2024.02.23

常见的tomcat漏洞有哪些
常见的tomcat漏洞有哪些

常见的tomcat漏洞有:1、跨站脚本攻击;2、跨站请求伪造;3、目录遍历漏洞;4、缓冲区溢出漏洞;5、配置漏洞;6、第三方组件漏洞。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

169

2024.02.23

tomcat日志乱码怎么解决
tomcat日志乱码怎么解决

tomcat日志乱码的解决办法:1、修改tomcat的日志编码设置;2、检查ide的编码设置;3、检查操作系统的编码设置;4、使用过滤器处理日志;5、检查外部系统的编码设置;6、检查文件编码方式等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

157

2024.02.23

weblogic和tomcat有哪些区别
weblogic和tomcat有哪些区别

weblogic和tomcat的区别:1、功能;2、性能;3、规模;4、价格;5、安全性;6、配置和管理;7、社区支持;8、集成能力;9、升级和更新;10、可靠性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

200

2024.02.23

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

244

2024.02.23

tomcat启动闪退怎么解决
tomcat启动闪退怎么解决

tomcat启动闪退的解决办法:1、检查java环境;2、检查环境变量配置;3、检查端口被占用;4、检查配置文件编码;5、检查启动时需要的配置文件;6、检查相关文件是否丢失;7、检查防火墙和杀毒软件设置。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

169

2024.02.23

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

2

2026.03.05

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 4.1万人学习

C# 教程
C# 教程

共94课时 | 10.7万人学习

Java 教程
Java 教程

共578课时 | 77.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号