破坏双亲委派模型
双亲委派主要出现过三次较大规模的“被破坏”的情况。
- JDK1.2之后,为避免
loadClass()
被子类覆盖的可能,建议用户重写findClass()
方法 - JNDI作为java的标准服务,需要调用启动类加载器不认识的外部接口(其他厂商实现的)
- IBM公司OSGI实现模块化热部署的关键是自定义类加载器机制,更换Bundle(程序模块)时,类加载器也会被换掉,然而类加载机制与双亲委派机制不同。
第一种情况
- 问题:类加载器的概念和抽象类的概念在java的第一个版本中就出现了,但是在jdk1.2及以前并没有双亲委派机制,所以当java设计者想要引入双亲委派机制时就不得不做出一点妥协,包含兼容用户自己自己的代码(用户自定义类加载器的代码),无法再以技术手段避免loadClass()被子类覆盖的可能性。
- 解决:java设计者想出的办法是在java.lang.ClassLoader()中添加一个新的protected方法findClass(),并引导用户编写类加载逻辑时尽可能去重=写这个方法,而不是在lo