JVM 双亲委派机制(通俗易懂)

类加载器

Java是运行在Java的虚拟机(JVM)中的,我们在IDE中编写的Java源代码被编译器编译成.class的字节码文件。然后ClassLoader负责将这些class文件加载到JVM中去执行。JVM中提供了自上而下提供了三层的ClassLoader:

  1. BootstrapClassLoader(启动类加载器) :最顶层的加载类,由C++实现,负责加载 %JAVA_HOME%/lib目录下的jar包和类或者或被 -Xbootclasspath参数指定的路径中的所有类。
  2. ExtensionClassLoader(扩展类加载器) :主要负责加载目录 %JRE_HOME%/lib/ext 目录下的jar包和类,或被 java.ext.dirs 系统变量所指定的路径下的jar包。
  3. AppClassLoader(应用程序类加载器) :面向我们用户的加载器,负责加载当前应用classpath下的所有jar包和类。

双亲委派机制

当一个.class文件要被加载时。不考虑自定义的类加载器,首先会在AppClassLoader中检查是否加载过,如果有那就无需再加载了。如果没有,那么会拿到父加载器,然后调用父加载器ExtClassLoader。父类中同样会先检查自己是否已经加载过,如果没有再往上到BootstrapclassLoader这一层,先检查是否可以加载,如果可以则加载。反之,如果父加载器无法加载,会下沉到子加载器去加载,一直到最底层,如果没有任何加载器能加载,就会抛出ClassNotFoundException。

下面这张图可以很好的解释双亲委派机制

(图片来源:https://blog.csdn.net/codeyanbao/article/details/82875064

在这里插入图片描述

双亲委派模型的好处

双亲委派机制保证了Java程序的稳定运行,可以避免类的重复加载,也保证了Java的核心API不被篡改。如果有人想替换系统级别的类:String.java,篡改它的实现。在这种机制下这些系统的类已经被BootstrapclassLoader加载过了,所以并不会再去加载。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值