Java类加载机制是按需懒加载.class文件并生成Class对象的过程,采用双亲委派模型:启动类加载器(C++实现)、扩展类加载器、应用程序类加载器构成父子委派链,确保核心类不被篡改、避免重复加载、保障类唯一性;可自定义加载器或在Tomcat、SPI等场景破坏委派。

Java类加载机制,本质是把.class字节码文件读入JVM内存,并生成对应的java.lang.Class对象的过程。它不是一次性全量加载,而是按需懒加载——只有在首次使用(如new对象、调用静态方法、反射获取Class等)时才触发。
JVM自带三类核心类加载器,构成逻辑上的父子委派链(非Java继承关系):
JAVA_HOME/jre/lib下的核心类(如rt.jar中的java.lang.Object),Java代码中不可见(返回null)JAVA_HOME/jre/lib/ext目录下的扩展jar,父加载器是Bootstrapclasspath路径下的用户类,父加载器是Extension你还可以继承java.lang.ClassLoader写自定义加载器,用于从网络、数据库或加密包中加载类。
当某个类加载器收到加载请求(比如AppClassLoader要加载com.example.User),它不直接动手,而是按以下顺序执行:
立即学习“Java免费学习笔记(深入)”;
loadClass()调用父类的同名方法)com.example.User),就逐级向下回退整个过程像“先请示、再动手”,不是所有加载器都平等竞争,而是有明确优先级。
它解决三个关键问题:
java.lang.String,双亲委派会让Bootstrap先尝试加载——它早就在rt.jar里加载过了,所以你的版本根本不会被用上ClassA != ClassB),保证类型安全java.*类都由Bootstrap加载,所有javax.*扩展类由Extension加载,应用类由App加载——层级即信任等级标准机制很健壮,但某些场景需要绕过它:
WEB-INF/classes和lib,而不是委派给AppClassLoader,避免应用间类冲突Thread.currentThread().getContextClassLoader())反向委托,让Bootstrap能加载到应用提供的Driver实现loadClass()逻辑实现隔离与动态替换破坏的前提是清楚后果——比如绕过委派后,要自行处理类可见性、资源隔离和内存泄漏风险。
基本上就这些。理解双亲委派,关键不在背流程,而在明白它用“层级+缓存+委派”换来了安全、稳定和可预测——不是设计得复杂,而是不敢简单。
以上就是Java类加载机制是什么 Java双亲委派模型【原理】的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号