贝利信息

Java类加载机制是什么 Java双亲委派模型【原理】

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

Java类加载机制,本质是把.class字节码文件读入JVM内存,并生成对应的java.lang.Class对象的过程。它不是一次性全量加载

,而是按需懒加载——只有在首次使用(如new对象、调用静态方法、反射获取Class等)时才触发。

类加载器的三层结构

JVM自带三类核心类加载器,构成逻辑上的父子委派链(非Java继承关系):

你还可以继承java.lang.ClassLoader写自定义加载器,用于从网络、数据库或加密包中加载类。

双亲委派模型的核心流程

当某个类加载器收到加载请求(比如AppClassLoader要加载com.example.User),它不直接动手,而是按以下顺序执行:

整个过程像“先请示、再动手”,不是所有加载器都平等竞争,而是有明确优先级。

为什么必须用双亲委派?

它解决三个关键问题:

什么时候会破坏双亲委派?

标准机制很健壮,但某些场景需要绕过它:

破坏的前提是清楚后果——比如绕过委派后,要自行处理类可见性、资源隔离和内存泄漏风险。

基本上就这些。理解双亲委派,关键不在背流程,而在明白它用“层级+缓存+委派”换来了安全、稳定和可预测——不是设计得复杂,而是不敢简单。