你得先知道
在介绍双亲委派机制的时候,不得不提 ClassLoader 。说ClassLoader之前,我们得先了解下Java的基本知识。
Java是运行在Java的虚拟机(.class 的
JVM中提供了三层的ClassLoader:
ExtClassLoader:主要负责加载jre/
那如果有一个 Hello.class 文件是如何被加载到JVM中的呢?
双亲委派机制
我打开了我的ClassLoader 类。然后将代码翻到 loadClass 方法:
public Class> loadClass(String name) throws ClassNotFoundException {
return loadClass(name, false);
}
// -----:point_down::point_down:-----
protected Class> loadClass(String name, boolean resolve)
throws ClassNotFoundException
{
// First, check if the class has already been loaded
Class> c =
其实这段代码已经很好的解释了双亲委派机制,为了大家更容易理解,我做了一张图来描述一下上面一段代码到底是怎么做的:
从上图中我们就更容易理解了,当一个Hello.class这样的文件要被加载时。不考虑我们自定义检查是否加载过 ,如果有那就无需再加载了。如果没有,那么会拿到 父加载器 ,然后调用父加载器的 loadClass 方法。父类中同理会先检查自己是否已经加载过,如果没有再往上。注意这个过程,知道到达 Bootstrap classLoader 之前,都是没有哪个加载器自己选择加载的。如果父加载器无法加载,会下沉到子加载器去加载,一直到最底层,如果没有任何加载器能加载,就会抛出 ClassNotFoundException 。
为什么要设计这种机制
这种设计有个好处是,如果有人想替换系统级别的类:String.java。篡改它的实现,但是在这种机制下这些系统的类已经被Bootstrap classLoader加载过了,所以并不会再去加载,从一定程度上防止了危险代码的植入。