JVM原理介绍( 八 )


1.9.2. 类加载器
虚拟机设计团队把加载动作放到JVM外部实现,以便让应用程序决定如何获取所需的类,JVM提供了3种类加载器:
1.9.2.1. 启动类加载器(Bootstrap ClassLoader)
1. 负责加载 JAVA_HOMElib 目录中的,或通过-Xbootclasspath参数指定路径中的,且被虚拟机认可(按文件名识别,如rt.jar)的类 。
1.9.2.2. 扩展类加载器(Extension ClassLoader)
2. 负责加载 JAVA_HOMElibext 目录中的,或通过java.ext.dirs系统变量指定路径中的类库 。
1.9.2.3. 应用程序类加载器(Application ClassLoader):
3. 负责加载用户路径(classpath)上的类库 。JVM通过双亲委派模型进行类的加载,当然我们也可以通过继承java.lang.ClassLoader实现自定义的类加载器 。
 

JVM原理介绍

文章插图
 
2.9.3. 双亲委派
当一个类收到了类加载请求,他首先不会尝试自己去加载这个类,而是把这个请求委派给父类去完成,每一个层次类加载器都是如此,因此所有的加载请求都应该传送到启动类加载其中,只有当父类加载器反馈自己无法完成这个请求的时候(在它的加载路径下没有找到所需加载的Class),子类加载器才会尝试自己去加载 。采用双亲委派的一个好处是比如加载位于rt.jar包中的类java.lang.Object,不管是哪个加载器加载这个类,最终都是委托给顶层的启动类加载器进行加载,这样就保证了使用不同的类加载器最终得到的都是同样一个Object对象 。
 
JVM原理介绍

文章插图
 
1.9.4. OSGI(动态模型系统) OSGi(Open Service Gateway Initiative),
是面向Java的动态模型系统,是Java动态化模块化系统的一系列规范 。
1.9.4.1. 动态改变构造
OSGi服务平台提供在多种网络设备上无需重启的动态改变构造的功能 。为了最小化耦合度和促使这些耦合度可管理,OSGi技术提供一种面向服务的架构,它能使这些组件动态地发现对方 。
1.9.4.2. 模块化编程与热插拔
OSGi旨在为实现Java程序的模块化编程提供基础条件,基于OSGi的程序很可能可以实现模块级的热插拔功能,当程序升级更新时,可以只停用、重新安装然后启动程序的其中一部分,这对企业级程序开发来说是非常具有诱惑力的特性 。OSGi描绘了一个很美好的模块化开发目标,而且定义了实现这个目标的所需要服务与架构,同时也有成熟的框架进行实现支持 。但并非所有的应用都适合采用OSGi作为基础架构,它在提供强大功能同时,也引入了额外的复杂度,因为它不遵守了类加载的双亲委托模型 。

【JVM原理介绍】


推荐阅读