高频面试题-请把Java的双亲委派机制说清楚!

news/2024/9/3 0:29:27 标签: java, 面试, 编程语言, spring, jdk

这是我参与更文挑战的第5天,活动详情查看: 更文挑战

如果面试官问你,类加载过程是哪几步?

巴拉巴拉巴拉...~~(加载、验证、准备、解析、初始化)~~

见这小伙子面容惊奇,脸泛红光,不由自主的就问了一下双亲委派模型说一下吧;遇见没准备充分的,瞬间懵逼。

下面我们就来说一下这个一个有意思的虚拟机类加载机制。

一说起双亲委派,就必然要先聊一下Java中的类加载器。

Java中的类加载器

Bootstrap ClassLoader (启动类加载器)

Bootstrap ClassLoader,启动类加载,默认加载的是jdk\lib目录下jar中诸多类;

这个路径可以使用 -Xbootclasspath参数指定。

Extension ClassLoader (扩展类加载器)

Extension ClassLoader,扩展类加载器,默认加载jdk\lib\ext\目录下jar中诸多类;

这个路径可以使用 java.ext.dirs系统变量来更改。

Application ClassLoader (应用程序类加载器)

Application ClassLoader,应用程序类加载器,负责加载开发人员所编写的诸多类。

User ClassLoader (自定义类加载器)

自定义类加载器,当存在上述类加载器解决不了的特殊情况,或存在特殊要求时,可以自行实现类加载逻辑。

关系如图所示:

1.png

双亲委派模型是什么?

说完了类加载器,下面我们就说一下什么是双亲委派模型吧。

其是在JDK1.2期间被引入的,而后陆续被推荐给开发者,到目前已经成为了最常用的类加载器实现方式了。

双亲委派整个过程分为以下几步:

  1. 假设用户刚刚摸鱼写的Test类想进行加载,这个时候首先会发送给应用程序类加载器AppCloassLoader;

  2. 然后AppClassLoader并不会直接去加载Test类,而是会委派于父类加载器完成此操作,也就是ExtClassLoader;

  3. ExtClassLoader同样也不会直接去加载Test类,而是会继续委派于父类加载器完成,也就是BootstrapClassLoader;

  4. BootstrapClassLoader这个时候已经到顶层了,没有父类加载器了,所以BootstrapClassLoader会在jdk/lib目录下去搜索是否存在,因为这里是用户自己写的Test类,是不会存在于jdk下的,所以这个时候会给子类加载器一个反馈。

  5. ExtClassLoader收到父类加载器发送的反馈,知道了父类加载器并没有找到对应的类,爸爸靠不住,就只能自己来加载了,结果显而易见,自己也不行,没办法,只能给更下面的子类加载器了。

  6. AppClassLoader收到父类加载器的反馈,顿时明白,原来爸爸虽然是爸爸,但是他终究不能管儿子的私事,所以这时候,AppClassLoader就自己尝试去加载。

  7. 结果,就这样成功了,走了一大圈,兜兜转转还是自己干。

这个并没有那么复杂,我就不画图了哈,大家如果想看图,可以去网上再搜一下,我记得有个大佬画的就很形象。

为什么要使用双亲委派模型?

使用双亲委派模型,有一个很大的好处,就是避免原始类被覆盖的问题。

比如,用户编写了一个Object类,放入程序中加载。

当没有双亲委派机制时,就会出现重复的Object类,会给开发人员造成很大的困扰,本来就只需要基于JDK开发就好了,现在还得把JDK中的类全记住,避免编写重复的类。

当存在双亲委派机制时呢,整个事情就不一样了,每次加载类时,都会遵循双亲委派机制,去问父类是否可以加载,如果可以呢,那就不需要再次加载了,这样事情就变得简单了。(老子走的路,小子不能走 》.《)

如何打破双亲委派模型?

这个问题,其实就算是双亲委派模型中最深入的问题了,最起码中高级工程师面试,问到这也就下个话题了。

这里我也简单说一下吧,最常见的也是人们常说的有两种,分别是:

  1. 在自定义类加载器中,重写loadClass方法。

为什么呢?因为如果你去看ClassLoader类的源码时,你会发现,双亲委派的核心代码就是在这个方法中的;试想,你如果重写了这个方法,自然而然的就打破了双亲委派机制了。

2.png

  1. 使用线程上下文类加载器

因为双亲委派机制不能支持SPI(Service Provider Interface), 所以才会引入线程上下文类加载器,有了它,就可以打通双亲委派模型的层次结构来反向使用类加载器来完成类加载。

这个目前也是没有办法的事,涉及到SPI的目前都在使用这种方式来完成类加载,其中就包括常用到的JNDI、JDBC、JAXB等。

这里其实还有一个可以打破双亲委派模型的情况,那就是OSGI,这个解释是在《深入理解 Java虚拟机》这本书中,可能是这本书的作者本身就对OSGI比较熟悉,而且看简介还出过一本OSGI的书。

在很多应用环境中,OSGI被当做模块化热部署实现的关键,所以,这样就说明了,OSGI一定会对类加载过程做相应的一些措施。

因为这个并不常碰到,还是大家自行去查看吧,我就不在这赘述了。


http://www.niftyadmin.cn/n/902654.html

相关文章

高频面试题-请聊一下Spring中BeanFactory与FactoryBean的区别!

这是我参与更文挑战的第6天,活动详情查看: 更文挑战 如果你的简历上这么写,熟练掌握Spring,并对Spring源码有一定的见解(或者是读过Spring源码),那么无法避免的就是要问几个问题。 IOC的实现原理是什么? AO…

高频面试题-请说一下线程的生命周期!

这是我参与更文挑战的第7天,活动详情查看: 更文挑战 这算是一个关于线程的基础问题了,但是依然很多面试官还是会问一下,倘若这个问题就卡住了,通过的几率就大打折扣了。 下面一起来看一下吧! 当一个线程在创…

高频面试题-请讲一下Java的反射机制!

这是我参与更文挑战的第8天,活动详情查看: 更文挑战 这个反射其实算是一道初级升中级的面试题,也是初级必须了解,中级必须了解并熟练使用的知识技能。 接下来就开始聊聊吧。 什么是反射? 反射就是在程序运行状态中&…

今天说一下Spring的架构模块!

这是我参与更文挑战的第9天,活动详情查看: 更文挑战 这是一个基础知识篇,看到这篇文章的,希望去多多理解一些更多的底层知识,不要不求甚解,要知其然知己所以然。 spring整体架构 大约分为20个模块,书上大概…

Java基础-异常分类与处理方式

这是我参与更文挑战的第10天,活动详情查看: 更文挑战 异常分类 Error Error 类是指 java 运行时系统的内部错误和资源耗尽错误。应用程序不会抛出该类对象。如果 出现了这样的错误,除了告知用户,剩下的就是尽力使程序安全的终止。…

高频面试题-请聊一下JVM的内存结构!

这是我参与更文挑战的第11天,活动详情查看: 更文挑战 凡是三年以上开发经验的人,都会在简历上写上这么一句话,了解/熟悉JVM(内存结构),对垃圾回收机制有一定的理解。 但是往往大部分人是一问三不知的,或者是…

高频面试题-请聊一下JVM中堆和栈的区别!

这是我参与更文挑战的第12天,活动详情查看: 更文挑战 上一回我们说完了JVM的内存结构,将JVM中有哪些元素已经搞清了,链接在这:高频面试题-请聊一下JVM的内存结构! 今天就再根据之前的主题接着延伸一个更容易…

高频面试题-你知道垃圾回收机制涉及哪些算法吗?

theme: smartblue 这是我参与更文挑战的第13天,活动详情查看: 更文挑战 说到垃圾回收,首先就要先要了解垃圾回收机制涉及到的算法。 如果不了解JVM可以先去看看这几篇文章。 高频面试题-请聊一下JVM的内存结构! 高频面试题-请聊一…