打破双亲委派机制

简介: 打破双亲委派机制

在Java历史上,有过三次这种事件发生, 第一次被破坏,还是在双亲委派模型出现之前, 即JDK1.2 面世以前的“远古”时代。  由于双亲委派 模型在JDK1.2 之后 才被引入, 但是类加载器的概念和抽象类 java.lang.ClassLoader 则在 Java的 第一个版本中就已经存在, 面对已经存在的用户自定义类加载器的代码, Java 设计者不得不妥协, 为兼容这些代码, 无法再以技术手段避免loadClass() 被子类覆盖的可能性, 只能在JDK1.2 之后的java.lan g.ClassLoader 中添加一个新的protected 方法 findClass() , 并引导用户编写的类加载逻辑是尽可能去重写这个方法, 而不是在loadClass() 中编写代码。 按照loadClass() 方法的逻辑,如果父类加载失败, 会自动调用自己的findClass()方法来完成加载,这样既不影响用户按照自己的意愿去加载类, 又可以保证新写出来的类加载器是符合双亲委派规则的。


第二次被破坏的是 由这个模型的缺陷导致的,  双亲委派很好地解决了各个类加载器协作时基础类型的一致性问题(越基础的类由越上层的加载器进行加载),基础类型之所以被称为“基础”,是因为他们总是作为被用户代码继承、调用的API存在,但程序设计往往没有绝对不变的完美规则,如果有基础类型又要调回用户的用户的代码,该怎么办?


JNDI服务, JNDI服务是Java的标准服务, 它的代码启动类加载器来完成加载(在jdk1.3时加入到rt.jar的),肯定属于Java中很基础的类型了。但JDNI存在的目的就是对资源进行查找和集中管理,他需要调用其他厂商实现并部署在应用程序的ClassPath下的JNDI服务提供者接口(Service Provider Interface,SPI)的代码。启动类加载器不可能认识, 加载这些代码,该怎么办?


为了解决, Java设计团队引入了一个不太优雅的设计:线程上下文类加载器(Thread Context ClassLoader)。这个类加载器可以通过java.lang.Thread类的setContextClassLoader()方法进行设置,如果创建线程时还未设置, 他将会从父线程中继承一个,如果在应用程序的全局范围内都没有设置过的话, 那这个类加载器默认使用的就是应用程序类加载器。


为了解决这种不优雅的设计, 在JDK6时,jdk提供了 java.util.ServiceLoader类,在META-INF/services中的配置信息,辅以责任链模式, 这才算是给SPI的加载器提供了一种相对合理的解决方案。


第三次破坏是由于 用户对程序动态性的追求而导致的,这里所说的“动态性”指的是一些非常“热”门的名词:代码热替换(Hot Swap)、模块热部署(Hot Deployment)等。说白了就是希望Java应用程序能想我们的电脑外设那样,接上鼠标、U盘,不用重启机器就能立即使用,鼠标有问题或要升级就换个鼠标,不用关机也不用重启。


我们在开发中,遇到比较多的,网上也说的比较多的是,web容器 tomcat的加载,是破坏了双亲委派机制。


参考文献 >> 《深入Java 虚拟机》第三版

这本书写的很好, 有时间的朋友可以去看看。

收录于合集 #jvm

3

上一篇JVM 类加载机制


目录
相关文章
|
4月前
|
Java 数据库连接
什么是双亲委派?如何打破双亲委派?
什么是双亲委派?如何打破双亲委派?
128 0
|
4月前
|
Java 关系型数据库 MySQL
【JVM】JDBC案例打破双亲委派机制
【JVM】JDBC案例打破双亲委派机制
97 4
|
1月前
|
Java 编译器
什么是双亲委派机制?
什么是双亲委派机制?
32 3
|
1月前
|
前端开发 Java C++
双亲委派机制
这篇文章详细解释了Java中的双亲委派机制,包括其原理、类加载器的分类(启动类加载器、扩展类加载器、应用程序类加载器)以及它们之间的关系和作用。
|
2月前
|
关系型数据库 MySQL Java
spi机制打破双亲委派机制
在JDBC4及以上版本,连接MySQL数据库不再需要显式加载驱动(`Class.forName`),而是利用SPI机制。系统通过扫描`META-INF/services/java.sql.Driver`文件找到`com.mysql.cj.jdbc.Driver`并使用`ServiceLoader`由AppClassLoader加载。`DriverManager`在启动时加载所有可用的`Driver`实现,实现解耦和动态发现。虽然看起来逆向了双亲委派,但实际上每个类仍由适当的类加载器加载,保持了加载层次。
spi机制打破双亲委派机制
|
4月前
|
Java
【JVM】双亲委派机制、打破双亲委派机制
【JVM】双亲委派机制、打破双亲委派机制
47 1
|
Java 关系型数据库 MySQL
双亲委派机制,懂吧~ 那什么情况下需要破坏它,知道吗?
双亲委派机制,懂吧~ 那什么情况下需要破坏它,知道吗?
86 0
|
Java 应用服务中间件
JVM - 彻底理解打破双亲委派机制
JVM - 彻底理解打破双亲委派机制
113 0
JVM - 彻底理解打破双亲委派机制
|
前端开发 Java 容器
为什么破坏双亲委派机制?
为什么破坏双亲委派机制?
167 0
|
缓存 Java API
双亲委派机制是什么?
如果跟同事谈“双亲委派”,难免显得很八股了,但是这个“双亲委派”却是JVM在类加载环节必不可少的一个操作,充分的理解它,能够使我们更加良好的理解JVM在加载类的时候背后细节。不仅如此,在学习了解一些其他的技术,例如:SPI、OSGI等等,也能相辅相成,融会贯通,可谓“两仪生四象,四象生八卦”
205 1
双亲委派机制是什么?