要了解"双亲委派"机制,首先需要知道"类的加载机制"
一、类的加载机制
我们自己写的 java 源文件到最终运行,必须经过编译和类加载两个阶段:
编译的过程就是把.java 文件编译成.class 文件。
类加载的过程,就是把 class 文件装载到 JVM 内存中,装载完成以后就会得到一个 Class 对象,我们就可以使用 new 关键字来实例化这个对象
而类的加载过程,需要涉及类加载器。
JVM 在运行的时候,会产生 3 个类加载器,这三个类加载器组成了一个层级关系
每个类加载器分别去加载不同作用范围的 jar 包,比如:
Bootstrap ClassLoader,主要是负责 Java 核心类库的加载,也就是 %{JDK_HOME}\lib 下的rt.jar、resources.jar 等
Extension ClassLoader,主要负责%{JDK_HOME}\lib\ext 目录下的 jar 包和 class 文件
Application ClassLoader,主要负责当前应用里面的 classpath 下的所有 jar 包和类文件
除了系统自己提供的类加载器以外,还可以通过 ClassLoader 类实现自定义加载器,去满足一些特殊
场景的需求
二、双亲委派
所谓的父委托模型,就是按照类加载器的层级关系,逐层进行委派。
比如当需要加载一个 class 文件的时候,首先会把这个 class 的查询和加载委派给父加载器去执行,如果父加载器都无法加载,再尝试自己来加载这个 class。
这样设计的好处:
安全性,因为这种层级关系实际上代表的是一种优先级,也就是所有的类的加载,优先给 Bootstrap ClassLoader。那对于核心类库中的类,就没办法去破坏,比如自己写一个 java.lang.String,最终还是会交给启动类加载器。再加上每个类加载器的作用范围,那么自己写的 java.lang.String 就没办法去覆盖类库中类
可以避免重复加载导致程序混乱的问题,因为如果父加载器已经加载过了,那么子类就没必要去加载了